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FOREWORD 


Air  Force  Systems  Command  sponsored  two  MIL-STD-1553  Multiplex  Data 
Bus  Conferences,  one  in  1976  and  one  in  1978.  In  the  past  two  years, 
MIL-STD-1750  and  MIL-STD-1589  have  matured  to  the  point  of  justifying 
another  conference.  For  the  next  three  days  we  will  provide  an  update 
of  MIL-STD-1553B,  1750A,  1589B,  and  also  the  status  of  the  new  MIL-STD- 
1760,  and  the  progress  of  the  Ada  programming  language.  Significant 
interest  in  MIL-STD-1553B  systems  applications,  LSI  developments  and 
test  equipment,  as  well  as  the  publication  of  MIL-STD-1750A  and  1589B 
have  prompted  this  Avionics  Standardization  Conference.  Brig  Gen  Jacobs, 
Deputy  Chief  of  Staff,  Plans  and  Programs,  requested  this  conference, 
being  liosted  by  the  Aeronautical  Systems  Division,  Lt  Gen  Skantze, 

Commander. 

The  purpose  of  the  conference  is  to  present  Air  Force  standardization 
policy  and  the  status  of  the  military  standards,  to  exchange  data  on  lessons 
learned  from  system  applications,  and  to  present  new  hardware/software  de¬ 
velopments  in  support  of  these  standards. 

This  is  the  STANDARDS  Volume,  Volume  II  of  the  Standardization  Conference. 
Volume  I  will  contain  the  proceedings  and  papers  given  during  the  conference, 
which  will  be  sent  to  attendees  at  a  later  date. 

Many  thanks  to  Captain  David  Herrelko  (AFSC/XR)  and  Major  A1  Kopp 
(AFSC/XRF)  for  their  headquarter's  assistance  in  organizing  this  conference; 
also  to  the  ASD/ENA  staff  who  assisted  in  organizing  the  technical  program, 
proceedings  and  exhibits,  Mr.  Stephen  Smith  and  Mr.  Erwin  Gangl.  Special 
thanks  to  Mr.  Joseph  Militello  (University  of  Dayton  Research  Institute) 
who  did  an  outstanding  job  in  organizing  the  conference  facilities,  hotel 
accommodations  and  food  service. 

Thanks  also  to  the  moderators  and  all  the  speakers  who  responsed  with 
outstanding  presentations  and  papers  in  a  timely  manner  despite  such  short 
notice.  And,  finally  to  the  secretaries,  Mrs.  Marie  Jankovich,  Mrs.  Kathy 
Hayes,  and  Mrs.  Sharleen  Thompson  for  their  expert  administrative  help  in 
handling  the  conference  correspondence  and  registration. 


ROBERT  P.  LAVOIE,  Colonel,  USAF 
Director,  Avionics  Engineering 
Deputv  for  Engineering 
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MIL-S) D- 17S0(USAr)  Instruction  Set  Architecture  Conference 


ASD/CV 

1.  We  arc  im|ircssccl  witli  your  sir.ni  f  icant  technoloj’icril  jiroj'.rcss  in 
developing  and  im]ilcnienting  our  Airhorne  roinpiiter  Instruction  Set 
Architecture,  MIL-STD-1750(USAr)  .  ii\c  toatr,uork  of  ASD/AX,  A.Sd/I  N  and 
the  AFKAI./AA  has  been  a  key  factor  in  this  successful  effort.  Tlie 
cntliusiastic  industry-wide  response  to  this  standardization  initiative 
attests  to  the  soundness  of  the  approach.  With  over  a  dozen  .-on- 
tractors  iniplcmenting  the  17r.O  architecture,  and  with  the  strong  inter¬ 
est  being  shown  by  systems  houses  and  airframe  irinrufacturers ,  the  time 
seems  right  for  a  conference  devoted  to  MIL-S'fb- 17S0. 

2.  We  request  you  host  such  a  conference,  in  coniunction  with  the  Fall 
meetings  of  the  MIL-STl)-1750  Users  '.roup  and  the  Mlh-.STD-l/SO  Control 
Board,  which  we  understand  will  bo  Imld  at  hr i glit -Patterson  Air  Force 
Base.  This  seems  an  oxccllont  time  to  tiemonst rat c  actual  working  hard¬ 
ware,  to  exchange  information  throu:'.h  presentations  and  a  published 
proceedings  of  the  conference,  and  to  show  off  FN’s  .SiAFAC  facility, 
which  has  a  central  role  in  MIL-SIP- 1 750  vcrificatiofi. 

3.  The  AFSC  project  officer  for  this  effort,  Capt.'iin  I'avid  A,  llerrelko 
(AFSC/XRF) ,  AUTOVON  858-5731,  is  prepared  to  provide  you  vith  any 
assistance  you  might  need  in  arranging  this  conference. 


FOR  TllF.  COMMAiVDLR 
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AFSC/XR 

1.  Reference  your  letter  of  29  April  1980,  Subject:  M1L-STD-1750(USAF) 
Instruction  Set  Architecture  Conference.  ASD/EN  took  on  tlie  task  to 
support  tlie  MIL-STD-1750  conference.  We  had  originally  planned  to 
schedule  this  conference  for  mid-September.  For  a  variety  of  reasons, 
we  elected  to  expand  the  scope  of  this  conference  to  cover  all  current 
AFSC  standardisation  initiatives  and  issues.  We  have  discussed  this 
witli  ASD/AX  and  ASD/XR  and  have  jointly  agreed  to  separate  the  1750 
Technical  Users'  Group  meeting  from  the  broader  aspects  of  tlie  conference. 
We  liave  tentatively  resclieduled  it  for  the  period  of  18  througli  20  Ilovembcr 
and  plan  to  include  MlL-STDs-1750A,  -1589,  -1553B,  and  -1760. 

2.  We  believe  it  would  be  more  effective  to  target  such  a  conference  to 
SI’O  level  managers  and  engineers  and  their  counterparts  in  industry,  in 
order  to  facilitate  application  of  tl\cse  standards  to  specific  programs. 

We  want  to  make  it  an  educational  rather  than  a  technical  symposium.  This 
will  afford  us  tlie  opportunity  to  present  our  perception  of  tlie  benefits 
we  expect  from  incorporating  tlie  standards;  present  the  status  of  key 
efforts  supporting  each  of  these;  and  present  lessons  learned  to  date 
where  we  have  had  some  actual  experience  in  applying  them.  We  will  al^ 
plan  to  address  DOD  standardization  policy  where  it  applies  and  will  pro¬ 
vide  the  opportunity  for  Headquarters  personnel  to  make  inputs  addressing 
specific  USAF  and  AFSC  intentions.  We  also  intend  to  provide  our  people 
some  insight  into  foreign  applications  of  our  military  standards. 

3.  I  would  appreciate  your  support  of  this  conference  and  your  concurrence 
that  this  approach  will  satisfy  your  original  request.  The  Directorate  of 
Avionics  Engineering,  ASD/ENA,  will  run  the  show  for  ASD.  Our  project 
officers  are  Mr.  Erwin  C.  Gangl,  ASD/ENAI,  Autovon  785-A865  and 

Mr.  Stephen  Smith,  ASD/ENAIB,  Autovon  785-2248.  They  are  prepared  to 
provide  your  staff  with  any  information  they  may  need  or  wish  to  have 
relative  to  the  details  of  the  conference. 
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SUBJFXT:  AFSC  Avionics  Stnnd.irdizntlon  Conference,  18  -  20  Novembci  1980 


JO;  CONFERENCF  ATTE^Li^XS 


1.  The  Aeronaiitlcnl  Systems  Division  Is  or enn  1  z  1  np,  and  bnstlni;  a 
conferenco  on  Avlonlrs  Standardization  at  tlie  Dayton  Convent  I  n 
Center,  18  -  20  November  1980.  Ibis  conference  will  address  Air 
Force  Avionics  Standardization  Policy,  tlic  status  of  MII.-STD-ISSJ 
(Multiplexed  Data  Bus).  MI  1,-STD- 1 ? SO  (Computer  Instruction  Se' 
Arcbltectiire)  ,  M 1 1,- STD- 1  589  (.171  lUpJipr  Order  Lanpuape),  Mll.-Sril- 
1760  (Aircraft  to  Stores  l.lertrlcal  interfare),  and  -tbe  progress 
of  the  new  International  lllgbcr  Order  Language,  Ada. 

2.  We  have  taipeted  tbis  r  on  f t  enr  ti’  rafne.e  t  s  and  rnplnr-'.-  | 
the  Systems  rrogram  Offices  and  antosparc  'ndiistry  !o  facll!''t‘e 
the  application  of  tbese  stanilardr  to  Air  I'orcc  prt'rrams  i>r;ir...t 
vou  cncotirnRC  attendance  of  vour  kev  iiersoai'el  to  Incteasr'  t''rlr 
unders t and  1 np  and  appreciation  of  tbe  benefits  to  Le  gained  from 
applying  these  standards. 

9.  We  plan  to  make  It  an  cdnratlonal  ratiier  than  terbnira’  s\"r|'r- 
slum.  Tills  will  affoinl  n'  the  oprnrlnnlly  '  i'lesrnt  on,  porrr,-,'  •• 
of  tbe  benefits  i.'o  expect  f  r  om  I ,,,  o ,  po  r  a  i  | ,,  ,•  (  Im  s  I  a  n  I  a  t  !  ,  :  r  "S ,  ” 

tbe  status  of  key  efforts  '•ppo,  !lni'  ea’  b  -  Ibrsn,  t  I  yi  ‘  li's-mo 

learned  to  date  irliore  oe  b/ive  bad  some  artual  experience  in  apnls  trp 
them.  We  will  also  plan  to  .address  I'WO  s  i  anda  r,l  1  za  t  1  on  roll';.  ..nerr 
It  applies,  and  will  provide  tbe  opportunity  tor  lle.id'iun  r  '  e  r  '  s  person¬ 
nel  to  make  l,ipnts  ablresslnp  specific  ll.SAF  and  AFSC  1  nt  r "  t  1  on  .  In 
addition,  we  will  piovldi  attendees  some  Insipbt  Into  foreign  accep¬ 
tance  and  system  applications  of  r  be.se  military  standards. 

.  A  rr'lnlmal  '.iil',',  I  sten'- '•  fvn  "xf  fl.no  p,'[-  person  will  b'-  ciiMn  I  •' 
maximize  a  t  t  end .anc e  .  !■' r p  I  s r  t  a  t  I ' nr  will  be  .at  tbe  rb 'o r  .uni  a  1  n e s 

will  receive  .i  comp  I  imen  t  .ary  copy  of  tbe  pro'Ccdln,ys 
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Aircraft  Internal  Time  liivlsion  (.ommand/ Hesi>onse  Multiplex  Lata  Bus 
MIL-STU-1553B 

1.  This  Military  Standard  is  approved  lor  us*'  tiy  all  U-[.artment  and  Agencies 
of  the  Department  of  Defense. 

2.  beneliciai  comments  (recommendations,  o...ditions,  deletions)  and  any 
pertinent  data  which  may  be  of  use  in  improving  this  document  should  be 
addressed  to;  Aeronautical  Systems  Division,  Attn:  tNAl,  Wriglit-Katterson  Air 
Force  base  45*133,  by  using  the  self  addressed  Stanoardization  Document 
Improvement  Proposal  (DD  Form  1426)  appearing  at  the  end  'vt  this  document  or  by 
letter . 


I 


?1  September'  1Q78 


(•  uHKWoHl 

'rtils  -stanbat'ii  oontains  recjui  r’ement  3  lot'  aircraft,  internal  time  division 
command,  response  multiplex  data  bus  techniijues  wbicn  will  oe  utilized  in 
systems  integration  of  air'oratt  subsystems.  Even  witti  the  use  of  this 
standard,  subtle  d  i  t ! er ences  will  exist  between  multiplex  data  buses  used  on 
different  aircraft  due  to  particular  aircraft  mlsniori  requirements  and  the 
designer  options  alittwed  in  this  standar'il .  Ih*;  system  designer  must  recognize 
this  fact  and  design  tfie  multiplex  bus  controller’  hardware  and  software  to 
accommodate  such  differences.  These  designer  selected  options  must  exist,  so 
as  to  allow  the  necessary  flexibility  in  the  design  of  specific  multiplex 
systems  in  order  to  provide  for  the  control  mechanism,  architecture  re  .dancy, 
degradation  concept  and  traffic  patterns  peculiar  to  the  specific  aircraft 
mission  requirernents  . 
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1 .  SCOPE 

1.1  Scope .  This  standard  establishes  requirements  ior  digital, 

command/ response  ,  time  division  multiplexing  (Data  bus)  techniques  on  aircraft. 
It  encompasses  the  data  bus  line  and  its  interface  electronics  illustrated  on 
figure  1,  and  also  defines  the  concept  of  operation  and  information  flow  on  the 
multiplex  data  bus  and  the  electrical  and  functional  formats  to  be  employed. 

1.2  Application .  When  invoked  In  a  specification  or  statement  of  work,  these 
requirements  shall  apply  to  the  multiplex  data  bus  and  associated  equipment 
which  is  developed  either  alone  or  as  a  portion  of  an  aircraft  weapon  system  or 
subsystem  development.  The  contractor  is  responsible  for  invoking  all  the 
applicable  requirements  of  this  Military  Standard  on  any  and  all  subcontractors 
he  may  employ. 

2.  REFEHENCED  DOCUMENTS 

2.1  Issue  of  <j9(;pment..  The  following  docunent,  of  the  issue  In  effect  on  date 
of  invitation  for  bid  or  request  for  proposal,  forms  a  part  of  the  standard  to 
the  extent  specified  herein. 

SPECIFICATION 

MILITARf 

MIL-E-6051  Electromagnetic  Compatibility  Requirements,  Systems 

(Copies  of  specifications,  standards,  drawings,  and  publications  required  by 
contractors  In  connection  with  specific  procurement  functions  should  be 
obtained  from  the  procuring  activity  or  as  directed  by  the  contracting 
officer . ) 

3.  DEFINITIONS 

3.1  Bit .  Contraction  of  binary  digit:  may  be  either  zero  or  one.  In 
information  theory  a  binary  digit  is  equal  to  one  binary  decision  or  the 
designation  of  one  of  two  possible  values  or  states  of  anything  used  to  store 
or  convey  information. 

3.2  bit  rate.  The  number  of  bits  transmitted  per  second. 

3.3  Pulse  code  modulation  (PCM) .  The  form  of  modulation  in  which  the 
modulation  signal  is  sampled,  quantized,  and  coded  so  that  each  element  of 
Information  consists  of  different  types  or  nimbers  of  pulses  and  spaces. 

3.4  Time  division  multiplexing  (TDM).  The  transmission  of  Information  from 
several  signal  sources  through  one  communication  system  with  different  signal 
samples  staggered  in  time  to  form  a  composite  pulse  train. 

3.5  Half  duplex.  Operation  of  a  data  transfer  system  In  either  direction  over 
a  single  line,  but  not  In  both  directions  on  that  line  simultaneously. 


3.6  JtPCl.  in  this  docunent  a  word  is  a  sequence  of  16  bits  plus  sync  and 
parity.  There  are  three  types  of  words:  commamd ,  status  and  data. 
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3-7  Message  ■  A  single  message  Is  the  transmission  of  a  command  word,  status 
word,  and  data  words  if  they  are  specified.  For  the  case  of  a  remote  terminal 
to  remote  terminal  (RT  to  HT)  transmission,  the  message  shall  include  the  two 
command  words,  the  two  status  words,  and  data  words. 

3*8  Subsystem .  The  device  or  functional  unit  receiving  data  transfer  service 
from  the  data  bus. 

3-9  Data  bus.  Whenever  a  data  bus  or  bus  is  referred  to  in  this  docment  it 
shall  imply  all  the  hardware  Including  twisted  shielded  pair  cables.  Isolation 
resistors,  transformers,  etc.,  required  to  provide  a  single  data  path  between 
the  bus  controller  and  all  the  associated  remote  terminals. 

3*  10  Terminal .  The  electronic  module  necessary  to  interface  the  data  bus  with 
the  subsystem  and  the  subsystem  with  the  data  bus.  Terminals  may  exist  as 
separate  line  replaceable  units  (LRU's)  or  be  contained  within  the  elements  of 
the  subsystem. 

3.11  bus  controller.  The  terminal  assigned  the  task  of  initiating  information 
transfers  on  the  data  bus. 

3.12  Bus  monitor .  The  terminal  assigned  the  task  of  receiving  bus  traffic  and 
extracting  selected  information  to  be  used  at  a  later  time. 

3.13  Remote  terminal  (RT).  All  terminals  not  operating  as  the  bus  controller 
or  as  a  bus  monitor. 

3.1*1  Asynchronous  operation.  For  the  purpose  of  this  standard,  asynchronous 
operation  is  the  use  of  an  independent  clock  source  in  each  terminal  for 
message  transmission.  Decoding  is  achieved  in  receiving  terminals  using  clock 
information  derived  from  the  message. 

3. 15  Dynamic  bus  control .  The  operation  of  a  data  bus  system  in  which 
designated  terminals  are  offered  control  of  the  data  bus. 

3.16  Cnmmand/ResDonse .  Operation  of  a  data  bus  system  such  that  remote 
terminals  receive  and  transmit  data  only  when  commanded  to  do  so  by  the  bus 
controller . 

3. 17  Redundant  data  bus.  The  use  of  more  than  one  data  bus  to  provide  more 
than  one  data  path  between  the  subsystems,  l.e.,  dual  redundant  data  bus, 
trl-redundant  data  bus,  etc. 

3.  18  Broadcast .  Operation  of  a  data  bus  system  such  that  information 
transmitted  by  the  bus  controller  or  a  remote  terminal  is  addressed  to  more 
than  one  of  the  remote  terminals  connected  to  the  data  bus. 

3.19  Mode  code .  A  means  by  which  the  bus  controller  can  communicate  with  the 
multiplex  bus  related  hardware,  in  order  to  assist  in  the  management  of 
information  flow. 
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4.  CENbRAL  REQUIREMENTS 

R. 1  Teat  and  operating  requirements.  All  requirements  aa  specified  herein 
shall  be  valid  over  the  environmental  conditions  which  the  multiplex  data  bus 
system  shall  be  required  to  operate. 

4.2  Data  bus  operation.  The  multiplex  data  bus  system  in  Its  most  elemental 
configuration  shall  be  as  shown  on  figure  l.  The  multiplex  data  bus  system 
shall  function  asynchronously  In  a  comm and /response  mode,  and  transmission 
shall  occur  In  a  half-duplex  manner.  Sole  control  of  Information  transmission 
on  the  bus  shall  reside  with  the  bus  controller,  which  shall  Initiate  all 
transmissions.  The  information  flow  on  the  data  bus  shall  be  comprised  of 
messages  which  are.  In  turn,  formed  by  three  types  of  words  (command,  data,  and 
status)  as  defined  in  4. 3.3.5- 

4.3  Characteristics 

4.3*1  Data  form.  Digital  data  may  be  transmitted  In  any  desired  form, 
provided  that  the  chosen  form  shall  be  compatible  with  the  message  and  word 
formats  defined  In  this  standard.  Any  unused  bit  positions  In  a  word  shall  be 
transmitted  as  logic  zeros. 

4.3*2  Bit  priority.  The  most  significant  bit  shall  be  transmitted  first  with 
the  less  significant  bits  following  In  descending  order  of  value  In  the  data 
word.  The  number  of  bits  required  to  define  a  quantity  shall  be  consistent 
with  the  resolution  or  accuracy  required.  In  the  event  that  multiple  precision 
quantities  (information  accuracy  or  resolution  requiring  more  than  16  bits)  are 
transmitted,  the  most  significant  bits  shall  be  transmitted  first,  followed  by 
the  word(s)  containing  the  lesser  significant  bits  in  nixnerical  descending 
order.  Bit  packing  of  multiple  quantities  in  a  single  data  word  Is  permitted. 

4.3.3  Transmission  method 

4.3.3. 1  Modulation.  The  signal  shall  be  transferred  over  the  data  bus  in 
serial  digital  pulse  code  modulation  form. 

4. 3. 3. 2  Data  code.  The  data  code  shall  be  Manchester  II  bl-phase  level.  A 
logic  one  shall  be  transmitted  as  a  bipolar  coded  signal  1/0  (l.e.,  a  positive 
pulse  followed  by  a  negative  pulse) .  A  logic  zero  shall  be  a  bipolar  coded 
signal  0/1  (l.e.,  a  negative  pulse  followed  by  a  positive  pulse).  A  transition 
through  zero  occurs  at  the  midpoint  of  each  bit  time  (see  figure  2). 

4. 3. 3. 3  Transmission  bit  rate.  The  transmission  bit  rate  on  the  bus  shall  be 
1.0  megabit  per  second  with  a  combined  accuracy  and  long-term  stability  of  i 
0.1  percent  (l.e.,  i  1000  Hsrtz  (Hz)).  The  short-term  stability  (l.e., 
stability  over  1.0  second  Interval)  shall  be  at  least  0.01  percent  (l.e.,  *  100 
Hz) . 

4. 3* 3*  4  Word  size.  The  word  size  shall  be  16  bits  plus  the  .«»ync  waveform  and 
the  parity  bit  for  a  total  of  20  bits  times  as  shown  on  figure  3- 

4. 3*3*5  Word  formats.  The  word  formats  shall  be  as  shown  on  figure  3  for  the 
command,  data,  and  status  words. 
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^•3'3-5'1  word.  A  command  word  shall  be  comprised  of  a  sync  waveform, 

remote  terminal  address  field,  transmit/receive  (T/h)  bit,  subaddress/mode 
field,  word  count/mode  code  field,  and  a  parity  (P)  bit  (see  figure  3)* 

4.3. 3.5.  1.1  Svnc .  The  command  sync  waveform  shall  be  an  invalid  Manchester 
waveform  as  shown  on  figure  H.  The  width  shall  be  three  bit  times,  with  the 
sync  waveform  being  positive  for  the  first  one  and  one-half  bit  times,  and  then 
negative  for  the  following  one  and  one-lialf  bit  times.  If  the  next  bit 
following  the  sync  waveform  is  a  logic  zero,  then  the  last  half  of  the  sync 
waveform  will  have  an  apparent  width  of  two  clock  periods  due  to  the  Manchester 
encoding . 

4. 3. 3. 5. 1.2  Remote  tt^rmlnai  address.  The  next  five  bits  following  the  sync 
shall  be  the  RT  address.  Each  RT  shall  be  assigned  a  unique  address.  Decimal 
address  31  (11111)  shall  not  be  assigned  as  a  unique  address.  In  addition  to 
its  unique  address,  a  RT  shall  be  assigned  decimal  address  31  (11111)  as  the 
common  address,  if  the  broadcast  option  is  used. 

4. 3. 3. 5. 1.3  Tran.salt/recel ve.  The  next  bit  following  the  remote  terminal 
address  shall  be  the  T/B  bit,  which  shall  indicate  the  action  required  of  the 
RT.  A  logic  zero  shall  indicate  the  RT  is  to  receive,  and  a  logic  one  shall 
Indicate  the  RT  is  to  transmit. 

4. 3. 3. 5. 1.4  -Subaddress/mode .  The  next  five  bits  following  the  R/T  bit  shall 
be  utilized  to  indicate  an  RT  subaddress  or  use  of  mode  control,  as  is  dictated 
by  the  Individual  terminal  requirements.  The  subaddress/mode  values  of  00000 
and  11111  are  reserved  for  special  purposes,  as  specified  in  4. 3.3.5. 1.7,  and 
ahall  not  be  utilized  for  any  other  function. 

4. 3. 3. 5. 1.5  Data  word  oount/mode  codfi.  The  next  five  bits  following  the 
subaddreas/mode  field  shail  be  the  quantity  of  data  words  to  be  either  sent  out 
or  received  by  the  RT  or  the  optional  mode  code  as  specified  in  4. 3-3. 5. 1.7.  A 
maximum  of  32  data  words  may  be  transmitted  or  received  in  any  one  message 
block.  Ail  ra  shall  indicate  a  decimal  count  of  31,  and  all  O’s  shall 
indicate  a  decimal  count  of  32. 

4. 3. 3. 5. 1.6  Parity.  The  last  bit  in  the  word  shall  be  used  for  parity  over 
the  preceding  16  bits.  Odd  parity  shail  be  utilized. 

4. 3. 3. 5. 1.7  Optional  mode  control.  For  BT’s  exercising  this  option  a 
subaddress/mode  code  of  00000  or  11111  shail  imply  that  the  contents  of  the 
data  word  count/mode  code  field  are  to  be  decoded  as  a  five  bit  mode  coPimand. 
The  mode  code  shall  only  be  used  to  communicate  with  the  multiplex  bus  related 
hardware,  and  to  assist  in  the  management  of  information  flow,  and  not  to 
extract  data  from  or  feed  data  to  a  functional  subsystem.  Codes  00000  through 
01111  shall  only  be  used  for  mode  codes  which  do  not  require  transfer  of  a  data 
word.  For  these  codes,  the  T/R  bit  shail  be  set  to  1.  Codes  10000  through 
mil  shall  only  be  used  for  m.)de  codes  which  require  transfer  of  a  single,  data 
word.  For  these  mode  codes,  the  T/R  bit  shall  Indicate  the  direction  of  data 
word  flow  as  specified  in  4.3.3.5.I.3.  No  multiple  data  word  transfer  shail  be 
Implemented  with  any  mode  code.  The  mode  codes  are  reserved  for  the  specific 
functions  as  specified  in  table  1  and  shall  not  be  used  for  any  other  purpose. 
If  the  designer  chooses  to  implement  any  of  these  functions,  the  specific 
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codes,  T'h  Pit  assigtimctiLs ,  and  use  of  a  data  woi  a ,  shall  be  used  as  indicated. 
The  use  of  the  broadi'ast  c,>mraand  option  shall  only  be  applied  to  particular 
mode  codes  as  specified  in  table  I. 

M  .  3 . 3 .8 . 1  .7 . 1  Dynamic  bus  control.  The  control ler  shall  Issue  a  transmit 
command  to  an  RT  capable  of  performing  the  bus  control  function.  This  RT  shall 
respond  with  a  status  word  as  sp(?cified  In  4.  1.5.3.  Control  of  the  data  bus 
passes  from  the  offioing  bus  conLr.iiier  to  the  acoeptlng  RT  upon  completion  of 
the  transmission  of  the  status  word  by  the  RT .  If  the  RT  rejects  control  of 
the  data  bus,  the  offering  bus  contriiller  retains  c.introl  of  the  data  bus. 

. 3 . 3 .5 . 1 .7  .2  Synchronize  (without  data  word).  This  command  shall  cause  the 
RT  to  synchronize  (e.g.,  to  reset  the  internal  timer,  to  start  a  sequence, 
etc.).  The  RT  shall  transmit  the  status  word  as  specified  in  4. 3. 3. 5. 3. 

4 . 3 . 3 . 5 . 1 .7 . 3  Transmit  status  word.  This  command  shall  cause  the  RT  to 
transmit  the  status  word  associated  with  the  last  valid  command  word  preceding 
this  command.  This  mode  command  shall  not  alter  the  state  of  the  status  word. 

4 . 3 . 3 .5 . 1 .7 . 4  Initiate  seif  test.  This  command  shall  be  used  to  Initiate  self 
test  within  the  RT.  The  RT  shall  transmit  the  status  word  as  specified  In 

4. 3. 3. 5. 3. 

4 . 3 . 3 - 5 . 1 .7 .5  Transmitter  shutdown.  This  command  (to  only  be  used  with  dual 
redundant  bus  systems)  shall  cause  thi^  HT  to  disable  the  transmitter  associated 
with  the  redundant  bus.  The  RT  shall  not  comply  with  a  command  to  shut  down  a 
transmitter  on  the  bus  from  which  this  c.immand  is  received.  In  all  cases,  the 
RT  shall  respond  with  a  status  word  as  specified  In  *4. 3. 3. 5. 3  after  this 
command . 

4 . 3 • 3 .5 . 1  .7  .6  Override  transmitter  shutdown.  This  command  (to  only  be  used 
with  dual  redundant  bus  system)  shall  cause  the  RT  to  enable  a  transmitter 
which  was  previously  disabled.  The  RT  shall  not  comply  with  a  command  to 
enable  a  transmitter  on  the  bus  from  which  this  command  Is  received.  In  all 
cases,  the  RT  shall  respond  with  a  status  word  as  specified  in  4. 3. 3*5. 3  after 
this  command. 

4 .3 .3  .5 . 1 .7  .7  Inhibit  terminal  flag  (T/F)  bit.  This  command  shall  cause  the 
RT  to  sot  the  T/F  bit  in  the  status  word  specified  In  4. 3. 3. 5. 3  to  logic  zero 
until  otherwise  commanded.  The  HT  shall  transmit  the  status  word  as  specified 
In  4. 3. 3. 5. 3. 

4 . 3 .3  .5 . 1  .7  .8  Overr  ide  inhibit  I/F  bit.  This  command  shall  cause  the  RT  to 
override  the  Inhibit  T/F  bit  sp'-cified  in  4 . 3  .  3 -5 . 1 .7 .7  .  The  RT  shall  transmit 
the  status  word  as  specified  in  ‘t.3.3-‘1.3. 

4 . 3 . 3 .5 . 1  .7  .9  Reset  remote  terminal.  This  c >mmand  shall  bo  used  to  reset  the 
RT  to  a  power  up  initialized  state.  The  RT  shall  first  transmit  its  status 
word,  and  then  reset. 

4 . 3 . 3 - 5 . 1 .7 . 10  Reserved  mode  codes  (OlOQl  to  011  11).  These  mode  codes  are 
reserved  for  future  use  and  shall  not  be  used. 
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TABLE  I.  Assianed  mode 

LSiOfitivn 

codes 

Assoc  la  ted 
Data  Word 

1 

00000 

Dynamic  bus  Control 

NO 

1 

00001 

Synchronize 

No 

1 

00010 

Transmit  Status  Word 

NO 

1 

0001  1 

Initiate  Self  Teat 

No 

1 

0C100 

Transmitter  Shutdown 

NO 

1 

00101 

Override  Transmitter  Shutdown 

NO 

1 

00110 

Inhibit  Terminal  E'lag  Bit 

NO 

1 

00111 

Override  Inhibit  Terminal  flag 

bit 

NO 

1 

01000 

He set  Remote  Terminal 

No 

1 

01001 

1 

Reserved 

1 

No 

1 

1 

i 

01111 

Reserved 

No 

1 

10000 

Transmit  Vector  Word 

Yes 

0 

10001 

Synchronize 

Yes 

1 

10010 

Transmit  Last  Coounand 

Yes 

1 

10011 

Transmit  BIT  Word 

Yes 

0 

10100 

Selected  Transmitter  Shutdown 

Yes 

0 

10101 

Override  Selected  Transmitter 

Yes 

1  or 

0  10110 

1 

Shutdown 

Reserved 

1 

Yes 

1 

1  or 

* 

0  11111 

1 

Reserved 

* 

Yes 

NOTE:  To  be  determined  (TBD) 
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Broadcast 
Conunand  Allowed 

No 

yes 

No 

yes 

yes 

yes 

yes 

yes 

yes 

TBD 

i 

TBD 

No 

yes 

No 

No 

Yes 

Yes 

TBD 

I 

TBD 
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I* .  3 .  i .  S .  1 .  7  •  1  1  Iransmit  vector  word.  Hus  ccfmmand  .■■hall  oause  the  HT  to 
fransmlt  a  status  word  a.s  specified  iti  and  a  data  word  cootalning 

-service  request  information. 

Svnclironize  (with  data  wordj.  Itie  hi  stiali  receive  a  command 
word  followed  by  a  data  word  as  Sfieclfied  in  h .  3.  3 . .  Ttie  data  word  shall 
contain  synchronization  Information  for  tne  hi.  Aft«r  receiving  the  command 
and  data  word,  the  hi  shall  transmit  the  status  word  as  specified  in  *4.  3- 3-5  3- 

14.3.3.5.1.7.13  Transmit  last  command  word.  Ihi.s  command  shall  cause  the  HT  to 
transmit  Its  status  word  as  specified  in  *4. 3. 3. 5. 3  followed  by  a  single  data 
word  which  contains  bits  ii-iy  of  the  last  command  word,  excluding  a  transmit 
last  command  word  mode  code  received  by  ttie  HT.  This  mode  command  shall  not 
alter  the  state  of  the  HT's  statu.s  word. 

44.3.3.5.1.7.114  Transmit  built- In-test  (bll  )  word.  Ihis  command  shall  cause 
the  HT  to  transmit  Its  status  word  as  specif  ied  in  44.  3- 3.5.  3  followed  by  a 
single  data  word  containing  the  HT  BIT  data.  This  f  unction  is  Intended  to 
supplement  the  available  bits  in  the  status  word  wiien  the  HI  hardware  Is 
sufficiently  complex  to  warrant  Its  use.  The  data  word,  containing  the  RT  BIT 
data,  shall  not  be  altered  by  the  reception  of  a  ti-ansmit  last  command  or  a 
transmit  status  word  mode  code.  This  function  shall  not  be  used  to  convey  BIT 
data  from  the  associated  subsystemi s) . 

4.3.3.5.1.7.15  Selected  transmitter  shutdown.  This  command  shall  cause  the  RT 
to  disable  the  transmitter  associated  with  a  specified  redundant  data  bus.  The 
command  is  designed  for  use  with  systems  employing  more  than  two  redundant 
buses.  The  transmitter  that  Is  to  be  disabled  stiall  be  Identified  In  the  data 
word  following  the  command  word  In  the  format  as  specified  in  4. 3. 3,5.2.  The 
RT  shall  not  comply  with  a  command  to  shut  down  a  transmitter  on  the  bus  from 
which  this  command  Is  received.  In  all  oases,  the  HT  shall  respond  with  a 
status  word  as  specified  in  4.3.3.5.3. 

44. 3. 3-5.  1.7  -  16  Override  selected  transmitter  shutdown .  This  commauid  shal  1 
cause  the  HT  to  enable  a  transmitter  which  was  previously  disabled.  The 
command  Is  designed  for  use  with  systems  employing  more  tlian  two  redundant 
buses.  The  transmitter  that  is  to  be  enabled  shall  be  Identified  In  the  data 
word  following  the  command  word  in  tne  format  as  specified  In  4. 3- 3- 5- 2.  The 
HT  shall  not  comply  with  a  command  to  enable  a  transmitter  on  the  bus  from 
which  this  command  is  received.  In  all  cases,  the  HT  shall  respond  with  a 
status  word  as  specified  in  4.3.3.5.3- 

14.3.3.5.1.7.17  Reserved  mode  codes  (10110  to  11111J.  Tiiese  mode  codes  are 
reserved  for  future  use  and  shall  not  l)e  used. 

44.  3- 3.5.2  Data  word .  A  data  word  shall  be  compri.sed  of  a  sync  waveform,  data 
bits,  and  a  parity  bit  (see  figure  3). 

44.3.3.5.2.1  iivnc  .  The  data  sync  waveform  shall  be  an  invalid  Manchester 
waveform  as  shown  on  figure  5.  The  wldtli  shall  be  three  bit  times,  with  the 
waveform  being  negative  for  the  first  one  and  one-half  bit  times,  and  then 
f«..sitive  for  the  following  one  and  one-half  bit  timer..  Note  that  if  the  bits 
preceding  and  following  the  sync  are  logic  ones,  then  the  apparent  width  of  the 
.sync  wavelorm  will  be  increa.ned  to  lour  bit  times. 
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**-3-3-5.2.2  Uata  ■  The  sixteen  bits  fullowing  the  sync  shall  be  utilized  for 
data  transmission  as  specltied  in  4.3.2. 

4. 3. 3.5. 2. 3  Parity .  The  last  bit  shall  be  utilized  lor  parity  as  specified  In 
4. 3. 3. 5.  1.6. 

4. 1.3. 5. 3  Status  word.  A  status  word  shall  be  comprised  of  a  sync  waveform, 

RT  address,  messagu  erroi-  bit,  instrumentation  bit,  service  request  bit,  three 
reserved  bits,  broadcast  command  received  bit,  busy  bit,  subsystem  flag  bit, 
dynamic  bus  control  acceptance  bit,  terminal  flag  bit,  and  a  parity  bit.  For 
optional  broadcast  operation,  transmission  of  the  status  word  shall  be 
suppressed  as  specified  in  4. 3. 3. 6. 7. 

4. 3. 3. 5. 3.1  Svne.  The  status  sync  waveform  shall  be  as  specified  in 

4. 3. 3. 5. 1.1. 

4. 3. 3. 5. 3. 2  HT  address.  The  next  five  bits  following  the  syno  shall  contain 
the  address  of  the  RT  which  is  transmitting  the  status  word  as  defined  in 

4. 3. 3. 5. 1.2. 

4. 3 .3 .5. 3.3  Message  error  bit.  The  status  word  bit  at  bit  time  nine  (see 
figure  3)  shall  be  utilized  to  indicate  that  one  or  more  of  the  data  words 
associated  with  the  preceding  receive  command  word  from  the  bus  controller  has 
failed  to  pass  the  RT's  validity  tests  as  specified  in  4. 4. 1.1.  This  bit  shall 
also  be  set  under  the  conditions  specified  in  4. 4. 1.2,  4. 4. 3. 4  and  4. 4. 3.6.  A 
logic  one  .shall  indicate  the  presence  of  a  message  error,  and  a  logic  zero 
shall  show  its  absence.  All  RT's  shall  implement  the  message  error  bit. 

4. 3. 3. 5. 3. 4  Instrumentation  bit.  The  status  word  at  bit  time  ten  (see  figure 
3)  shall  be  reserved  for  the  instrumentation  bit  and  shall  always  be  a  logic 
zero.  This  bit  is  intended  to  be  used  in  conjunction  with  a  logic  one  in  bit 
tiM  ten  of  the  comound  word  to  distinguish  between  a  command  word  and  a  status 
word.  The  use  of  the  instrumentation  bit  is  optional. 

4. 3. 3. 5. 3. 5  Service  request  bit.  The  status  word  bit  at  bit  time  eleven  (see 
figure  3)  shall  be  reserved  for  the  service  request  bit.  The  use  of  this  bit 
is  optional.  This  bit  when  used,  shall  indicate  the  need  for  the  bus 
controller  to  take  specific  predefined  actions  relative  to  either  the  RT  or 
associated  subsystem.  Multiple  subsystems,  interfaced  to  a  single  RT,  which 
individually  require  a  service  request  signal  shall  logically  OR  their 
individual  signals  into  the  single  status  word  bit.  In  the  event  this  logical 
OR  is  performed,  then  the  designer  must  make  provisions  in  a  separate  data  word 
to  identify  the  specific  requesting  subsystem.  The  service  request  bit  is 
intended  to  be  used  only  to  trigger  data  transfer  operations  which  take  place 
on  an  exception  rather  than  periodic  basis.  A  logic  one  shall  Indicate  the 
presence  of  a  service  request,  and  a  logic  zero  its  absence.  If  this  function 
is  not  implemented,  the  bit  shall  be  set  to  zero. 

4. 3. 3. 5. 3. 6  Reserved  status  bits.  The  status  word  bits  at  bit  times  twelve 
through  fourteen  are  reserved  for  future  use  and  shall  not  be  used.  These  bits 
shall  be  set  to  a  logic  zero. 
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‘*.3. 3. 5. 3. 7  Broadcaat  pnmmann  received  bit.  The  status  word  at  bit  time 
rirteen  shall  be  set  to  a  logio  one  to  indlrate  that  the  preceding  valid 
command  word  was  a  broadcast  command  and  a  logic  zero  shall  show  it  was  not  a 
broadcast  command.  If  the  broadcast  command  option  is  not  used,  this  bit  shall 
bo  set  to  a  logic  zero. 

*1.3. 3. 5. 3. 8  Busy  bit.  The  status  word  hit  at  bit  time  sixteen  (see  figure  3) 
shall  be  reserved  for  the  busy  bit.  The  use  of  this  bit  Is  optional.  This 
bit,  when  used,  shall  indicate  that  the  HT  or  subsystem  Is  unable  to  move  data 
to  or  from  the  subsystem  In  compliance  with  trie  bus  controller's  command.  A 
logic  one  shall  indicate  the  presence  of  a  busy  condition,  and  a  logic  zero  its 
absence.  In  the  event  the  busy  bit  Is  set  In  response  to  a  transmit  command, 
then  the  RT  shall  transmit  its  status  word  only.  If  this  function  is  not 
implemented,  the  bit  shall  be  set  to  logi<'  zero. 

*t.3.3.5.3.9  Subsystem  flag  bit.  The  status  word  bit  at  bit  time  seventeen 
(see  figure  3)  shall  be  reserved  for  the  subsystem  flag  bit.  The  use  of  this 
bit  is  optional.  This  bit,  when  used,  shall  flag  a  subsystem  fault  condition, 
and  alert  the  bus  controller  to  potentially  invalid  data.  Multiple  subsystems, 
interfaced  to  a  single  RT,  which  individually  require  a  subsystem  flag  bit 
signal  shall  logically  OR  their  individual  signals  Into  the  single  status  word 
bit.  In  the  event  this  logical  OR  is  performed,  then  the  designer  must  make 
provisions  in  a  separate  data  word  to  Identify  the  specific  reporting 
subsystem.  A  logic  one  shall  Indicate  the  presence  of  the  flag,  and  a  logic 
zero  its  absence.  If  not  used,  this  bit  shall  be  set  to  logic  zero. 

‘*.3.3.5.3.10  Dynamic  bus  control  acceptance  bit.  The  status  word  bit  at  bit 
time  eighteen  (see  figure  3)  shall  be  reserved  for  the  acceptance  of  dynamic 
bus  control.  This  bit  shall  be  used  if  the  RT  implements  the  optional  dynamic 
bus  control  function.  This  bit,  when  used,  shall  indicate  acceptance  or 
rejection  of  a  dynamic  bus  control  offer  as  specified  in  *•  .3.3 .5 . 1 .7 . 1 .  A 
logic  one  shall  indicate  acceptance  of  control,  and  a  logic  zero  shall  indicate 
rejection  of  control.  If  this  function  is  net  used,  this  bit  shall  be  set  to 
logic  zero. 

‘•.3.3.5.3.11  Terminal  flag  bit.  The  status  word  bit  at  bit  time  nineteen  (see 

figure  3)  shall  be  reserved  for  the  terminal  flag  function.  The  use  of  this 

bit  is  optional.  This  bit,  when  used,  shall  flag  a  RT  fault  condition.  A 

logic  one  shall  indicate  the  presence  of  the  flag,  and  a  logic  zero,  its 
absence.  If  not  used,  this  bit  shall  be  set  to  logic  zero. 

‘*.3.3.5.3.12  Parity  bit.  The  least  significant  bit  In  the  status  word  shall 
be  utilized  for  parity  as  specified  in  •« .  3 . 3  .5 . 1  , 6  . 

‘*.3.3.5.**  Status  word  reset.  The  status  word  bit,  with  the  exception  of  the 
address,  shall  be  set  to  logic  zero  after  a  valid  command  word  is  received  by 
the  RT  with  the  exception  as  speclfioq  in  R . 3 . 3 .S . 1 .” .  If  the  conditions  which 
caused  bits  in  the  status  word  !■>  be  sot  (e.g.,  terminal  flag)  continue  after 
the  bits  are  reset  to  logic  zero,  thn  the  affected  status  word  bit  shall  be 
again  set,  and  then  transmitted  on  the  bus  as  required. 

k.3.3.6  Message  formats.  The  raessagos  transmitted  on  the  data  bus  Shall  be  in 
accordance  with  the  formats  on  figure  b  and  figure  .  The  maximum  and  lainimum 
response  times  shall  be  as  stated  in  4.3.3.?  and  4. 3. 3. 8.  No  message  formats, 
other  than  those  defined  herein,  shall  be  used  on  the  bus. 
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bus  cotitruiief  to  femute  tcTunnai  translers.  The  bus  controller 
shall  issue  a  receive  axninaitj  lullowed  by  the  specified  niinber  of  data  words. 

The  HT  shall  ,  after  message  validation,  transmit  a  status  word  back  to  the 
controller.  The  command  and  uata  words  -shall  be  transmitted  in  a  contiguous 
fashion  with  no  inleiwiird  gaps. 

k.3.3.6.2  Hemote  terminal  to  bus  controller  transfers.  The  bus  controller 
shall  issue  a  transmit  coomiand  to  the  Kl ,  The  RT  shall,  after  command  word 
validation,  transmit  a  status  word  back  to  tl>e  bus  controller,  followed  by  the 
specified  nunber  of  data  words.  The  status  and  data  words  shall  be  transmitted 
In  a  contiguous  fashion  with  no  interword  gaps. 

'••3. 3. 6. 3  fifiBQte  terainai  to  remote  terminal  transfers.  The  bus  controller 
shall  Issue  a  receive  command  to  RT  A  followed  contiguously  by  a  transmit 
command  to  RT  B.  RT  6  shall,  after  command  validation,  transmit  a  status  word 
followed  by  the  specified  number  of  data  words.  The  status  and  data  words 
shall  be  transmitted  in  a  contiguous  fashion  with  no  gap.  At  the  conclusion  of 
the  data  transmission  by  RT  B,  RT  A  shall  transmit  a  status  word  within  the 
specified  time  period. 

4. 3. 3-  6. 4  Mode  command  without  data  word.  The  bus  controller  shall  Issue  a 
transmit  command  to  the  RT  using  a  mode  code  specified  in  table  I.  The  RT 
shall,  after  command  word  validation,  transmit  a  status  word. 

4. 3. 3.6.5  Mode  command  with  data  word  (transmit).  The  bus  controller  shall 
issue  a  transmit  command  to  the  RT  using  a  mode  code  specified  in  table  I.  The 
RT  shall,  after  command  word  validation,  transmit  a  status  word  followed  by  one 
data  word.  The  status  word  and  data  word  shall  be  transmitted  in  a  contiguous 
fashion  with  no  gap. 

4.  3.  3- 5- 6  Mode  wHtl  word  (receive).  The  bus  controller  shall 

Issue  a  receive  command  to  the  RT  using  a  mode  code  specified  in  table  1, 
followed  by  one  data  word.  The  command  word  and  data  word  shall  be  transmitted 
in  a  contiguous  fashion  with  no  gap.  The  RT  shall,  after  command  and  data  word 
validation,  transmit  a  status  word  back  to  the  controller. 

4. 3. 3- 6.7  Optional  broadcast  command.  See  10.6  for  additional  information  on 
the  use  of  the  broadcast  command. 

4 . 3 . 3 • 6 . 7 .  1  bus  controller  to  remote  terminal(s)  transfer  (broadcast) .  The 
bus  controller  shall  Issue  a  receive  command  word  with  1111)  in  the  RT  address 
field  followed  by  the  specified  nunber  of  data  words.  The  command  word  and 
data  words  shall  be  transmitted  in  a  contiguous  fashion  with  no  gap.  The  RT{si 
with  the  broadcast  option  shall  after  message  validation,  set  the  broadcast 
conunand  received  bit  in  the  status  word  as  specified  in  4. 3. 3. 5. 3*7  and  shall 
not  transmit  the  status  word. 
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M.3-3-6.7.2  Remote  terminal  to  remote  termlnalCs)  transfera  (broadcast).  The 
bu5  controller  shall  Issue  a  receive  command  word  with  11111  In  the  RT  address 
field  followed  by  a  transmit  command  to  RT  A  using  the  RT's  address.  RT  A 
shall,  after  command  word  validation,  transmit  a  status  word  followed  by  the 
specified  number  of  data  words.  The  status  and  data  words  shall  be  transmitted 
In  a  contiguous  fashion  with  no  gap.  Tlie  RT(s)  with  the  broadcast  option, 
excluding  HT  A,  shall  after  message  validation,  set  the  broadcast  received  bit 
in  the  status  word  as  specified  in  M. 3. 3. 5. 3. 7  and  shall  not  transmit  the 
status  word . 

4.3-3-6.7.3  Mode  comnmnd  without  data  word  (broadcast).  The  bus  controller 
shall  issue  a  transmit  command  word  with  11111  in  the  RT  address  field,  and  a 
mode  code  specified  in  table  1.  The  RT(s)  with  the  broadcast  option  shall 
after  command  word  validation,  set  the  broadcast  received  bit  in  the  status 
word  as  specified  in  ‘l.3<3<5<3>7  and  shall  not  transmit  the  status  word. 

14.3.3.6.7.^  Mode  command  with  data  word  (broadcast).  The  bus  controller  shall 
issue  a  receive  command  word  with  11111  in  the  RT  address  field  and  a  mode  code 
specified  in  table  1,  followed  by  one  data  word.  The  command  word  and  data 
wcrd  shall  be  transmitted  in  a  contiguous  fashion  with  no  gap.  The  RT(s)  with 
the  broadcast  option  shall  after  message  validation,  set  the  broadcast  received 
bit  in  the  status  word  as  specified  in  <4. 3*3. 5. 3. 7  and  shall  not  transmit  the 
status  word . 

*4. 3. 3.7  Intermessaae  gap.  The  bus  controller  shall  provide  a  minimum  gap  time 
of  I4.0  microseconds  (jjs)  between  messages  as  shown  on  figure  6  and  figure  7. 
Ihis  time  period,  shown  as  T  on  figure  8,  is  measured  at  point  A  of  the  bus 
controller  as  shown  on  figure  9  or  figure  10.  The  time  is  measured  from  the 
mid-bit  zero  crossing  of  the  last  bit  of  the  preceding  message  to  mid-zero 
crossing  of  the  next  command  word  sync. 

44.3.3.8  Response  time.  The  RT  shall  respond,  in  accordance  with  44.3.3.6,  to  a 
valid  command  word  within  the  time  period  of  4.0  to  12.0  its.  This  time  period, 
shown  as  T  on  figure  8,  is  measured  at  point  A  of  the  RT  as  shown  on  figure  9 
or  figure  10.  The  time  is  measured  from  the  mid  bit  zero  crossing  of  the  last 
word  as  specified  in  *4. 3. 3. 6  and  as  shown  on  figure  6  and  figure  7  to  the 
mid-zero  crossing  of  the  status  word  sync. 

44.3.3.9  Minimum  no-resDonse  time-out.  The  minirouB  time  that  a  terminal  shall 
wait  before  considering  that  a  response  as  specified  in  44.3.3.8  iiot 
occurred  shall  be  14.0  iis.  The  time  is  measured  from  the  mid-bit  zero  crossing 
of  the  last  bit  of  the  last  word  to  the  mid-zero  crossing  of  the  expected 
status  word  sync  at  point  A  of  the  terminal  as  shown  on  figure  9  or  figure  10. 

4.4  Terminal  operation. 

4.4.1  rnmmnn  operation.  Terminals  shall  have  common  operating  capabilities  as 
specified  in  the  following  paragraphs. 
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FIOURF,  9.  Data  bus  Interface  using  transformer  coupling. 
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i(.ii.1.1  Word  validation.  The  terminal  shall  insure  that  each  word  conforms  to 
the  following  minlmiin  criteria: 

a.  The  word  begins  with  a  valid  sync  field. 

b.  TTie  bits  are  In  a  valid  Manchester  11  code. 

c.  The  Information  field  has  16  bits  plus  parity. 

d.  The  word  parity  is  odd. 

When  a  word  falls  to  conform  to  the  preceding  criteria,  the  word  shall  be 
considered  Invalid. 

‘••‘1-1.2  Transmission  continuity.  The  te.-minal  shall  verify  that  the  message 
Is  contiguous  as  defined  In  <4.3.3-6.  Improperly  timed  data  syncs  shall  be 
considered  a  message  error. 

*1. *1.1.3  Terminal  fail-safe.  The  terminal  shall  contain  a  hardware  Implemented 
time-out  to  preclude  a  signal  transmission  of  greater  than  800.0  iis .  This 
hardware  shall  not  preclude  a  correct  transmission  in  response  to  a  command. 
Reset  of  this  time-out  function  shall  be  performed  by  the  reception  of  a  valid 
command  on  the  bus  on  which  the  time-out  has  occurred. 

‘t.*1.2  Bus  controller  operation.  A  terminal  operating  as  a  bus  controller 
shall  be  responsible  for  sending  data  bus  commands,  participating  in  data 
transfers,  receiving  status  responses,  and  monitoring  system  status  as  defined 
In  this  standard,  the  bus  controller  function  may  be  embodied  as  either  a 
stand-alone  terminal,  whose  sole  function  is  to  control  the  data  bus(s),  or 
contained  within  a  subsystem,  ttily  one  terminal  shall  be  In  active  control  of 
a  data  bus  at  any  one  time. 

*i.n.3  Remote  terminal. 

*i.*4.3.1  Operation.  A  remote  terminal  (RT)  shall  operate  in  response  to  valid 
commands  received  from  the  bus  controller.  The  RT  shall  accept  a  command  word 
as  valid  when  the  comffl^^1d  word  meets  the  criteria  of  4. *1.1.1,  and  the  command 
word  contains  a  terminal  address  which  matches  the  RT  address  or  an  address  of 
11111,  if  the  RT  has  the  brxjadcast  option. 

*1. *1.3.2  Superseding  valid  commands.  The  HT  shall  be  capable  of  receiving  a 
command  word  on  the  data  bus  after  the  minuous  intermessage  gap  time  as 
specified  in  *1.3. 3-7  has  been  exceeded,  when  the  RT  is  not  in  the  time  period  T 
as  specified  in  4. 3. 3.8  prior  to  the  transmission  of  a  status  word,  and  when  it 
is  not  transmitting  on  that  data  bus.  A  second  valid  command  word  sent  to  an 
RT  shall  take  precedence  over  the  previous  command.  The  RT  shall  respond  to 
the  second  valid  command  as  specified  in  *4. 3. 3. 6. 

**.4.3.3  Invalid  coaunands.  A  remote  terminal  siiall  not  respond  to  a  command 
word  which  fails  to  meet  thecritei-ia  specified  in  4.4.3.  1. 

4.4. 3. 4  Illegal  command.  An  illegal  command  is  a  valid  command  as  specified 
in  4. 4.  3.1,  where  the  bits  In  the  subaodres-s/mode  field,  data  word  count/mode 
code  field,  and  the  T/R  bit  indicate  a  mixlt-  (  001m  and  ,  subaddress,  or  word  count 
that  has  not  been  implemented  in  the  hi.  i*  is  the  responsibility  of  the  bus 
controller  to  assure  that  no  illegal  commands  are  .-^ent  out.  The  RT  designer 
has  the  option  of  monitoring  for  illegal  commands.  If  an  KT  that  is  designed 
with  this  option  detects  an  illegal  command  and  the  iroper  nunber  of  contiguous 
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valid  data  wjrds  as  apet'ifled  by  the  Illegal  commajul  word,  It  shall  reap^mU 
with  a  status  word  only,  setting  the  message  error  bit,  and  not  use  the 
Information  received. 

4.1(.3-5  Valid  data  reception.  The  remote  terminal  sfial  1  resjxjnd  with  a  status 
word  when  a  valid  command  word  and  the  proper  nimber  uf  contiguous  valid  data 
words  are  received,  or  a  single  valid  word  associated  with  a  mode  code  Is 
received.  Each  data  word  siiall  meet  the  criteria  specified  in  4.V.I.I. 

ii.ii.3.6  Invalid  data  reception.  Any  data  wordis)  associated  with  a  valid 
receive  command  that  does  not  meet  the  criteria  specllied  In  ll.ii.1.1  and 

4.14.1.2  or  an  error  in  the  data  word  count  shall  cause  the  remote  terminal  to 
set  the  message  error  bit  in  ttie  statu.s  word  to  a  logic  one  and  suppress  the 
transmission  of  the  status  word.  II  a  message  error  has  occurred,  then  the 
entire  message  shall  be  considered  invalid. 

I4.l4.44  Bus  monitor  operation.  A  terminal  operating  as  a  bus  monitor  shall 
receive  bus  traffic  and  extract  selected  Information.  Wnilo  operating  as  a  bus 
monitor,  the  terminal  shall  not  respond  to  any  message  except  one  containing 
Its  own  unique  address  if  one  is  assigned.  All  information  obtained  while 
acting  as  a  bus  monitor  shall  be  strictly  used  for  off-line  applications  (e.g., 
flight  test  recordirig,  maintenance  recording  or  mission  analysis)  or  to  provide 
the  back-up  bus  controller  sufficient  information  to  take  over  as  the  bus 
controller . 

4.5  tordware.  ctiaracteristics ■ 

**•5.1  Data  bus  characteristics. 

4.5.  1.1  Cable .  The  cable  used  for  the  main  bus  and  all  stubs  shall  be  a  two 
conductor,  twisted,  shielded,  jacketed  cable.  The  wire-to-wlre  distributed 
capacitance  shall  not  exceed  30.0  picofarads  per  foot.  The  cables  shall  be 
formed  with  not  less  than  four  twists  per  foot  where  a  twist  Is  defined  as  a 
360  degree  rotation  of  the  wire  pairs;  and,  the  cable  shield  shall  provide  a 
mlnlmin  of  75-0  percent  coverage. 

4. 5. 1.2  Characteristic  imnedance. .  The  nominal  characteristic  Impedance  of  the 
cable  (Zo^  shall  be  within  the  range  of  70.0  ohms  to  85.0  ohms  at  a  sinusoidal 
frequency  of  1.0  megahertz  (MHz). 

4.5.  1.3  Cable  attenuation.  At  the  frequency  of  4.5.  1.2,  the  cable  power  loss 
shall  not  exceed  1.5  decibels  (db)/100  feet  (ft). 

4.5. 1.4  Cable  termination.  The  two  ends  of  the  cable  shall  be  terminated  with 
a  resistance,  equal  to  the  selected  cable  nominal  characteristic  Impedance  (  Zq) 
i  2.0  percent. 

4.5.  1.5  Cable  stub  requirements.  The  cable  shall  be  coupled  to  the  terminal 
as  shown  on  figure  9  or  figure  10.  The  use  of  long  stubs  Is  discouraged,  and 
the  length  of  a  stub  should  be  minimized.  However,  if  Installation 
requirements  dictate,  stub  lengtfis  exceeding  those  lengths  specified  in 
4.5. 1.5.1  and  4.5. 1.5.2  are  permissible. 
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*1  •  5  •  1.S.1  lC3.!15J.^'nitC  stubs  .  Itie  lengtli  ol  a  trans  tortner  coupled  stub 

should  not  exceed  ,'()  teet  .  II  a  transf c.iiner  coupled  stub  is  used,  then  the 
following  shall  apiily, 

*1-5.  1.5.1.  1  boupltng  transl  ormer .  A  coupling  translornier  ,  as  shown  on  figure 
9,  shall  be  required.  'Ihis  trains  fonner  .shall  have  a  turns  ratio  of  1:1.91  + 

3-0  percent,  with  the  higher  turns  on  the  isolation  resistor  side  of  the  stub. 

*1 .5 . 1  .5 . 1  .  1  •  1  Transformer  input  impedance.  The  .>pen  circuit  Impedance  as  seen 
at  point  B  on  figure  11  shall  be  greater  than  3000  ohms  over  the  frequency 
range  of  75.0  kiloiiertz  (kHz)  t.i  1.0  megahertz  (MHz),  when  measured  with  a  1 .0  V 
root-mean-square  (RMS)  sin  wave. 

•*  .5 . 1 .5 . 1 . 1  .2  Transformer  waveform  integrity.  The  droop  of  the  transformer 
using  the  test  configuration  shown  on  figure  11  at  point  B,  shall  not  exceed 
20.0  percent.  Overshoot  and  ringing  as  measured  at  point  B  shall  be  less  that 
1  1.0  V  peak.  For  this  test,  R  shall  equal  360.0  ohms  ±  5.0  percent  and  the 
input  A  of  figure  11  shall  be  a  250.0  kHz  square  wave.  27.0  V  peak-to-peak , 
with  a  rise  and  fall  time  no  greater  than  100  nanoseconds  (ns). 

4  .5 . 1  .5 . 1  . 1  .3  Transformer  common  mode  relection.  The  coupling  transformer 
shall  have  a  common  mode  rejection  ratio  greater  than  95.0  dB  at  1.0  MHz. 

M. 5. 1.5. 1.2  Fault  isolation.  An  isolation  resistor  shall  be  placed  in  series 
with  each  connection  to  the  data  bus  cable.  This  resistor  shall  have  a  value 
of  0.75  Zq  ohms  plus  or  minus  2.0  percent,  where  Z©  1*  the  selected  cable 
nominal  characteristic  impedance.  The  impedance  placed  across  the  data  bus 
cable  shall  be  no  less  than  1.5  .)hms  for  any  failure  of  the  coupling 

transformer,  cable  stub,  or  terminal  transiiiitter/receiver. 

4. 5. 1.5. 1.3  Cable  coupling.  All  coupling  transformers  and  isolation 
resistors,  as  specified  in  9. 5. 1.5. 1.1  and  9. 5. 1.5. 1.2,  shall  have  continuous 
shielding  which  will  provide  a  minimum  of  T5  percent  coverage.  The  isolation 
resistors  and  coupling  transformers  shall  be  placed  at  minimum  possible 
distance  from  the  Junction  of  the  stub  to  the  main  bus. 

4. 5. 1.5.1  9  Stub  voltage  requirements.  Every  data  bus  shall  be  designed  such 
that  all  stubs  at  point  A  of  figure  9  shall  have  a  peak-to-peak  amplitude, 
llne-to-llhe  within  the  range  of  1.0  and  14.0  V  for  a  transmission  by  any 
terminal  on  the  data  bus.  This  shall  Include  the  maximum  reduction  of  data  bus 
signal  amplitude  In  the  event  that  one  of  the  terminals  has  a  fault  which 
causes  It  to  reflect  a  fault  impedance  specified  in  4. 5. 1.5. 1.2  on  the  data 
bus.  This  shall  also  include  the  worse  case  output  voltage  of  the  terminals  as 
specified  In  4. 5. 2. 1.1.1  and  4. 5. 2. 2. 1.1. 

4. 5. 1.5. 2  Direct  coupled  .stubs.  The  length  of  a  direct  coupled  stub  should 
not  exceed  1  foot.  Refer  to  10. 5  for  comments  concerning  direct  coiolad  stubs. 
If  a  direct  coupled  stub  is  used,  then. the  following  shall  apply. 

4. 5. 1.5. 2.1  Fault  Isolation.  An  isolation  resistor  shall  be  placed  In  series 
with  each  connection  to  the  data  bus  coble.  This  resistor  shall  have  a  value 
of  55.0  ohms  plus  or  minus  2.0  percent.  The  isolation  resistors  shall  be 
placed  within  the  RT  as  shown  on  figure  10. 
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FIGURE  1 2 .  Terminal  I/O  characteristics  for  trarrsf ormer  coupled  and  direct 
coupletl  stubs . 
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^•b■^.b^2.2  Cable  coupling.  All  bus-stub  Junctions  shall  have  continuous 
shielding  which  will  provide  a  mlnlmLin  of  75  percent  coverage. 

M. 5. 1.5. 2. 3  Stub  voltage  reouirumenta.  tvery  data  bus  shall  be  designed  such 
that  all  stubs  at  point  A  of  figure  10  shall  have  a  peak-to-peak  amplitude, 
llne-to-llne  within  the  range  «>f  1.4  and  20. (i  V  foi’  a  transmission  by  any 
terminal  on  the  data  bus.  This  shall  irieiude  liie  maximum  reduction  of  data 
bus  signal  amplitude  In  the  event  that  one  of  the  terminals  has  a  fault  which 
causes  It  to  reflect  a  fault  Impedance  of  110  ohms  on  the  data  bus.  This  shall 
also  Include  the  worst  case  output  voltage  of  the  terminals  as  specified  In 

4. 5. 2. 1.1.1  and  4. 5. 2. 2. 1.1. 

4. 5. 1.5. 3  Miring  and  cabling  for  IMC.  For  purposes  of  electromagnetic 
capability  (EMC),  the  wiring  and  cabling  provisions  of  MIL-E-6051  shall  apply. 

4.5.2  Terminal  characteristics. 

4. 5. 2.1  Terminals  with  transformer  coupled  stubs. 

4. 5. 2. 1.1  Terminal  output  characteristics.  The  following  characteristics 
shall  be  measured  with  Rl.  shown  on  figure  12,  equal  to  70.0  ohms  *2.0 
percent. 

4.5.2.  1.1.1  Output  levels.  The  terminal  output  voltage  levels  shall  be 
measured  using  the  teat  configuration  shown  on  figure  12.  The  terminal  output 
voltage  shall  be  within  the  range  of  18.0  to  27.0  V,  peak-to-peak, 
llne-to-llne,  when  measured  at  point  A  on  figure  12. 

4.5.2. 1.1.2  Output  waveform.  The  wavelonn,  when  measured  at  point  A  on  figure 
12  shall  have  zero  crossing  deviations  which  are  equal  to,  or  less  than,  25.0 
ns  from  the  Ideal  crossing  point,  measured  with  respect  to  the  previous  zero 
crossing  (1  .e  . ,  .5  *  . 025  us ,  1.0  +  .025  us ,  1.5  +  . 025  us ,  and  2.0  i  . 025  us) . 
Hie  rise  and  fall  time  of  this  waveform  shall  be  from  100.0  to  300.0  ns  when 
measured  from  levels  of  10  to  90  percent  of  full  waveform  peak-to-peak, 
llne-to-llne,  voltage  as  shown  on  figure  13.  Any  distortion  of  the  waveform 
Including  overshoot  and  rlnglrg  shall  not,  exceed  t  900.0  millivolts  (mV)  peak, 
llne-to-llne,  as  measured  at  point  A,  figure  12. 

4.5.2. 1.1.3  Output  noise.  Any  noise  transmitted  when  the  terminal  Is 
receiving  or  has  power  removed,  shall  not  exceed  a  value  of  14.0  mV,  RMS, 
llne-to-llne,  as  measured  at  point  A,  I  igure  12. 

4.5.2. 1.1.4  Output  symmetry,  trom  the  time  beginning  2.5  us  after  the  mld-blt 
crossing  of  the  parity  bit  of  the  last  word  transmitted  by  a  terminal,  the 
mcixlmiin  voltage  at  point  A  of  figure  12  shall  be  no  greater  than  *  250.0  mV 
peak,  1 ine- to-1  ine .  This  shall  be  tested  with  the  terminal  transmitting  the 
maxlmun  number  of  words  it  is  designed  to  transmit,  up  to  3i.  This  test  shall 
be  run  six  times  with  each  word  in  a  contiguous  blocK  of  words  having  the  same 
bit  pattern.  The  six  word  contents  that  shall  be  used  are  8000^^,  71‘FKi5, 

0000^5,  FFFF15,  5555ib.  AAAAi(,.  output  of  the  terminal  shall  be  as 

specified  in  4.5.2.  1.1.1  and  4.5.2. 1.1.2. 

4.5.2. 1.2  Terminal  Input  characteristics.  The  following  r bar ac ter i st Ic s  shall 
be  measured  independently. 
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U.'j.c'.  1  .  Y' .  1  iiiLJUl  wavflur'in  C'jiBiiaL  ib  1 1 1 1  v  .  Tlie  i.erminai  shall  be  capable  o( 
receiving  atiJ  ijperat  mg  wilh  t  h--  in'-cmitig  signals  spe<  ilieil  herein,  and  shall 
accept  wavelonn  varying  train  a  squai’e  wave  to  a  sine  wave  with  a  max  im urn  zero 
crossing  deviation  from  i  he  ideal  with  respect  to  ttie  previous  zero  crossing  of 
t  ISO  ns  ,  i  I  .e  .  ,  0  1  .  IS  iJS  ,  1 .  S  1  .  IS  ps  ,  1.0  1  .  IS  .us  ,  .5  1  .  15  >jsl  .  The 

terminal  shall  restxind  to  an  input  .signal  wliose  peak-to-peak  amplitude, 

1  ine- to- 1  ine ,  is  within  ttie  range  of  .B6  to  14.0  V.  The  terminal  shall  not 
respond  to  an  input  signal  who.se  (leak-to-peak  amplitude,  1  me- to-1  ine ,  is 
within  the  range  of  0.0  to  . ?0  V.  The  voltages  are  measured  at  point  A  on 
figure  9. 

4.5.2. 1.2.2  Common  mode  reject  ions.  Any  signals  from  direct  current  (DC)  to 
2.0  MHz, with  amplitudes  equal  to  or  less  than  1  10.0  V  peak,  1 ine- to-ground  , 
measured  at  point  A  on  figure  9,  shall  not  degrade  the  performance  of  the 

r ece  iver  . 

11.5.2.  1.2.3  Input  Impedance.  The  magnitude  of  the  terminal  Input  Impedance, 
when  the  RT  la  not  transmitting,  or  has  power  removed,  shall  be  a  alnlaua  of 
1000.0  ohms  within  the  frequency  range  of  75.0  khz  to  1.0  MHz.  This  lapedanee 
la  that  aeasured  llne-to-line  at  point  A  on  figure  9. 

11. 5. 2.  1 . 2.  il  Holae  re  lection  .  The  terminal  shall  exhibit  a  maxlaua  word  arror 
rate  of  one  part  In  10^,  on  all  words  received  by  the  terminal,  after 
validation  checks  as  specified  In  4.4,  when  operating  In  the  presence  of 
additive  white  Gaussian  noise  distributed  over  a  bandwidth  of  1.0  kHz  to  4.0 
MHz  at  an  RMS  amplitude  of  140  mV.  A  word  error  shall  Include  any  fault  which 
causes  the  message  error  bit  to  be  set  in  the  terminal’s  status  word,  or  ons 
which  causes  a  terminal  to  not  respond  to  a  valid  command.  The  word  arror  rate 
shall  be  aeasured  with  a  2. 1  V  peak-to-peak,  1  In e- to-1 Ine ,  input  to  the 
terminal  as  measured  at  point  A  on  figure  9.  The  noise  tests  shall  be  run 
continuously  until,  for  a  particular  number  of  failures,  the  niaiber  of  words 
received  by  the  terminal,  Including  both  command  and  data  words,  exceeds  the 
required  number  for  acceptance  of  the  terminal,  or  is  less  than  the  required 
number  for  rejection  of  the  terminal,  as  specified  In  table  11.  All  data  words 
used  In  the  tests  shall  contain  random  bit  patterns.  These  bit  pattsrns  shall 
be  unique  for  each  data  word  In  a  message,  and  shall  change  randomly  from 
message  to  message  . 

4. 5. 2. 2  Terminals  with  direct  coupled  stubs. 

4. 5. 2. 2.1  Terminal  cutout  characterlatlcs ■  The  following  charactsrlatlca 
shall  be  measured  with  R^^,  as  shown  on  figure  12,  equal  to  35.0  ohma  t  2.0 
percent . 


4. 5. 2. 2.  1.1  uutput  levels.  The  terminal  output  voltage  levels  shall  be 
meaaured  using  the  test  configuration  shown  on  figure  12.  The  terminal  output 
voltage  shall  be  within  the  range  of  b.O  to  9.0  V,  peak-to-peak,  llne-to-line, 
when  aeasured  at  point  A  on  figure  12. 
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Table  II,  Criteria  for  acceptance  or  reiection  of  a 
terminal  tor  the  noise  reiectlon  test 

TOTAL.  WORD.S  HECtIVtD  bT  THE  TKHMINAL 
(  in  multiples  of  lo7  ) 


No.  of 

he  jec  t 

Accept 

Errors 

(Eoual  or  less) 

(Eoual  or  more) 

0 

H/A 

9.  90 

1 

N/A 

5.21 

'•» 

c 

N/A 

6.02 

3 

N/A 

6.83 

9 

N/A 

7.69 

5 

N/A 

8.9  5 

6 

.95 

9.27 

7 

1.26 

10.08 

8 

2.07 

10.89 

9 

2.88 

11.70 

10 

3.69 

12.51 

1 1 

9.50 

1  3.  32 

12 

5.31 

19.13 

13 

6. 12 

19.99 

19 

6.93 

15.75 

15 

7.79 

16.56 

16 

8.55 

17.37 

17 

9.37 

18.19 

18 

10. 18 

19.00 

19 

10.99 

19.81 

20 

11 .80 

20.62 

21 

12.61 

21.93 

22 

13.92 

22.29 

23 

19.23 

23.05 

29 

15.09 

23.86 

25 

1b. 85 

29.67 

26 

16.66 

25.98 

27 

17.97 

26.29 

28 

18.29 

27.11 

29 

19.10 

27.92 

30 

19.90 

28.73 

31 

20.72 

29.59 

32 

21.53 

30.35 

33 

22.39 

31.16 

39 

23.  15 

31.97 

35 

23.96 

32.78 

36 

29.77 

■•■3 -00 

37 

25.58 

33-00 

36 

26.39 

33.00 

39 

27.21 

33.00 

90 

28.02 

33.00 

91 

33.00 

N/A 
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‘i.5-2.2.1.2  Output  waveiora.  The  waveform,  when  measured  at  point  A  on  figure 
12,  shall  have  zero  crossing  d/evlatlons  which  are  equal  to,  or  less  than,  25.0 
ns  from  the  Ideal  crossing  point,  measured  with  respect  to  the  previous  zero 
^sslng  (1  -e. ,  .5  1  .025  ws ,  1.0  t  .025  pa.  1.5  t  .025  US  and  2.0  +  .025  Jis)  . 
The  rise  and  fall  time  of  this  wavefonn  shall  be  Trom  100.0  to  300.0  ns  when 
measured  from  levels  of  10  to  90  percent  of  full  waveform  peak- to- peak , 
llne-to-llne ,  voltage  as  shown  on  figure  13.  Any  distortion  of  the  waveform 
including  overslyjot  and  ringing  shall  not  exceed  t  300.0  iiV  peak,  llne-to-llne, 
as  measured  at  point  A  on  figure  12. 


9. 5-2. 2.  1.3  Ql.tPUt  noise.  Any  noise  transmitted  when  the  t  rmlnal  is 
receiving  or  h,-is  power  removed,  shall  not  exceed  a  value  of  5.0  mV,  RMS, 
llne-to-llne,  as  measured  at  pwlnt  A  on  figure  12. 

9.5.2.2.1.11  Output  .svif|//ietry  From  the  time  beginning  2.5  us  after  the  mid-bit 
crossing  of  the  parity  bit  of  the  last  word  transmitted  by  a  terminal,  the 
maxlmun  voltage  at  point  A  on  figure  12,  shall  be  no  greater  than  t  90.0  mV 
peak,  llne-to-llne.  This  shall  be  tested  with  the  terminal  transmitting  the 
maxlmun  number  of  words  It  Is  designed  to  transmit,  up  to  33.  This  test  shall 
be  run  six  times  with  each  word  in  a  contiguous  block  of  words  having  the  same 
bit  pattern.  The  six  word  contents  that  shall  be  used  are  6OOO15,  7FFF15, 
OOOO15,  FFFF15,  555516,  and  AAAAig.  The  output  of  the  terminal  shall  be  as 
specified  In  9. 5. 2. 2. 1.1  and  9. 5. 2. 2. 1.2. 


9. 5. 2. 2. 2  Terminal  Input  characteristics.  The  following  characteristics  shall 
be  measured  independently. 


9. 5. 2. 2. 2.1  Input  waveform  compatibility.  The  terminal  shall  be  capable  of 
receiving  and  operating  with  the  incoming  signals  specified  herein,  and  shall 
accept  wa’eform  varying  from  a  square  wave  to  a  sine  wave  with  a  maximum  aero 
crossing  deviation  from  the  ideal  with  respect  to  ihe  previous  aero  crossing  of 
plus  or  minu.s  150  ns,  (l.e.,  2.0  ♦  ,15  1.5  ♦  .15  u,  1 .0  t  .15  us 

,5  t  .15  us).  The  terminal  shall  respond  to  an  Input  signal  whose  pemk-to-peak 
amplitude,  line-to-llne,  is  within  the  range  of  1.2  to  20.0  V.  The  terminal 
shall  not  respond  to  an  input  signal  whose  peak-to-peak  amplitude, 
llne-to-llne,  Is  within  the  range  of  0.0  to  .28  V.  The  voltages  ere  measured 
at  point  A  on  figure  10. 


4. 5 .2. 2. 2. 2  fiOMIon  ainilfi  rf  lections.  Any  signals  from  DC  to  2.0  MHa,  with 
amplitudes  equal  to  or  less  than  *  10.0  V  peak,  ilne-to-ground,  measured  at 
point  A  on  figure  10,  shall  not  degrade  the  performance  of  the  receiver. 

9. 5. 2. 2. 2. 3  Input  impedance.  The  magnitude  of  the  terminal  Input  Impedance, 
when  the  RT  Is  not  transmitting,  or  has  power  removed,  shall  be  a  minimum  of 
2000.0  ohms  within  the  frequency  range  of  "’5.0  kHz  to  1.0  MHz.  This  Impedance 
la  that  measured  llne-to-llne  at  point  A  on  figure  10. 


9. 5. 2. 2. 2. 9  Noise  re  )ectlon.  The  terminal  shall  exhibit  a  maximum  word  error 
rate  of  one  part  in  107,  on  all  words  .'-eceived  by  the  terminal,  after 
validation  checks  as  specified  in  9.4,  when  operating  In  the  presence  of 
additive  white  Gaussian  noise  distributee  over  a  bandwidth  of  1.0  kHz  to  9.0 
MHz  at  an  RMS  amplitude  of  200  mV.  A  word  error  shall  include  any  fault  which 
causes  the  message  error  bit  to  be  set  In  the  terminal's  status  word,  or  one 
which  causes  a  terminal  to  not  respond  to  a  valid  command.  The  word  error  rate 
shall  be  measured  with  a  3.0  V  peak-to-peak,  llne-lo-llne.  Input  to  the 
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terminal  as  measured  at  polrit  A  on  flgui-e  10.  The  noise  tests  shall  be  run 
continuously  until,  for  a  particular  nunber  of  failures,  the  nunber  of  words 
received  by  the  terminal,  including  both  command  and  data  words,  exceeds  the 
required  nunber  for  acceptance  of  the  term  inal <  or  is  less  than  the  required 
number  for  rejection  of  the  terminal,  as  specified  in  table  II.  All  data  words 
used  in  the  tests  shall  contain  random  bit  patterns.  These  bit  patterns  shall 
be  unique  for  each  data  word  in  a  message,  and  shall  change  randomly  from 
message  to  message  . 

4.6  Redundant  data  bus  requirements.  If  redundant  data  buses  are  used,  the 
requirements  as  specified  in  the  following  shall  apply  to  those  data  buses. 

4.6.1  Electrical  isolation.  All  terminals  shall  have  a  minimum  of  45  dB 
isolation  between  data  buses.  isolation  here  means  the  ratio  in  db  between  the 
output  voltage  on  the  active  data  bus  and  the  output  voltage  on  the  inactivt 
data  bus.  This  shall  be  measured  using  the  test  configuration  specified  in 

4.5.2. 1.1  or  4. 5. 2. 2.1  for  each  data  bus.  Each  data  bus  shall  be  alternately 
activated  with  all  measurements  being  taken  at  point  A  on  figure  12  for  each 
data  bus . 

4.6.2  Single  event  failures.  All  data  buses  shall  be  routed  to  minimize  the 
possibility  that  a  single  event  failure  to  a  data  bus  shall  cause  the  loss  of 
more  than  that  particular  data  bus. 

4.6.3  Dual  standby  redundant  data  bus.  If  a  dual  redundant  data  bus  is  used, 
then  it  shall  be  a  dual  standby  redundant  data  bus  as  specified  in  the 
following  paragraphs. 

4. 6.3.1  Data  bus  activity.  Only  one  data  bus  can  be  active  at  any  given  time 
except  as  specified  in  4.6. 3-2. 

4. 6. 3. 2  Reset  data  bus  transmitter.  If  while  operating  on  a  command,  a 
tenninal  receives  another  valid  command,  from  either  data  bus,  it  shall  reset 
and  respond  to  the  new  command  on  the  data  bus  on  which  the  new  command  is 
received.  The  terminal  shall  respond  to  the  new  command  as  specified  In 

4. 3. 3. 8. 


5.  DETAIL  REQUIREMENTS  (Not  Applicable) 

preparing  Activity: 
Air  Force  -  1 1 

Project  MISC-0D03 


Custodians: 

Army  -  EL 
Navy  -  AS 
Air  Force  -  11 
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APFbNblJ^ 

10.  tieneral  •  The  following  paragraphs  in  this  appendix  are  presented  in  order 
to  discuss  certain  aspects  of  the  standard  in  a  general  sense.  They  are 
Intended  to  provide  a  user  of  the  standard  more  insight  into  the  aspects 
discussed  . 

10.1  Redundancy .  It  is  intended  that  this  standard  be  used  to  support  rather 
than  to  supplcuit  the  system  design  process.  However,  it  has  been  found, 
through  application  experience  in  various  aircraft,  that  the  use  of  a  dual 
standby  redundancy  technique  is  very  desirable  for  use  in  integrating  mission 
avionics.  For  this  reason,  this  redundancy  scheme  is  defined  in  4.6  of  this 
standard.  None  the  less,  the  system  designer  should  utilize  this  standard  as 
the  needs  of  a  particular  application  dictate.  The  use  of  redundancy,  the 
degree  to  which  it  is  Implemented,  and  the  form  which  it  takes  must  be 
determined  on  an  individual  application  basis.  Figures  10.1  and  10.2 
illustrate  some  possible  approaches  to  dual  redundancy.  These  illustrations 
are  not  Intended  to  be  inclusive,  but  rather  representative.  It  should  be 
noted  that  analogous  approaches  exist  for  the  triple  and  quad  redundant  cases. 

10.2  Bus  controller.  The  bus  controller  is  a  key  part  of  the  data  bus  system. 
The  functions  of  the  bus  controller,  in  addition  to  the  issuance  of  commands, 
must  include  the  constant  monitoring  of  the  data  bus  and  the  traffic  on  the 
bus.  It  is  envisioned  that  most  of  the  routine  minute  details  of  bus 
monitoring  (e.g.,  parity  checking,  terminal  non-response  time-out,  etc.)  will 
be  embodied  in  hardware,  while  the  algorithms  for  bus  control  and  decision 
making  will  reside  in  software.  It  is  also  envisioned  that,  in  general,  the 
bus  controller  will  be  a  general  purpose  airborne  computer  with  a  special 
Input/output  (1/0)  to  Interface  with  the  data  bus.  It  is  of  extreme  importance 
in  bus  controller  design  that  the  bus  controller  be  readily  able  to  acconuDodate 
terminals  of  differing  protocol's  and  status  word  bits  used.  Equipment 
designed  to  MIL-STD-1 553A  will  be  in  use  for  a  considerable  period  of  time; 
thus,  bus  controllers  must  be  capable  of  adjusting  to  their  differing  needs. 

It  is  also  important  to  remember  that  the  bus  controller  will  be  the  focal 
point  for  modification  and  growth  within  the  multiplex  system,  and  thus  the 
softweu'e  must  be  written  in  such  a  manner  as  to  permit  modification  with 
relative  ease. 
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10.3  Multiplex  selection  criteria.  The  nelectioii  of  candidate  signals  for 
multiplexing  is  a  function  of  the  parti<Mjlar  application  Involved,  and  criteria 
will  in  general  vary  from  system  to  system.  Obviously,  those  signals  which 
have  bandwidths  of  900  Hz  or  less  are  prime  candidates  for  inclusion  on  the 
bus.  It  is  also  obvious  that  video,  audio,  and  high  speed  parallel  digital 
signals  should  be  excluded.  The  area  of  questionable  application  Is  usually 
between  900  Hz  and  3KHz  bandwidth.  The  transfer  of  these  signals  on  the  data 
bus  will  depend  heavily  upon  the  loading  of  the  bus  in  a  particular 
application.  The  decision  must  be  based  on  projected  future  bus  needs  as  well 
as  the  current  loading.  Another  class  of  signals  which  in  general  are  not 
suitable  for  multiplexing  are  those  which  can  be  typified  by  a  low  rate  (over  a 
mission)  but  possessing  a  high  priority  or  urgency.  Examples  of  such  signals 
might  be  a  nuclear  event  detector  output  or  a  missile  launch  alarm  from  a 
warning  receiver.  Such  signals  are  usually  better  left  hardwired,  but  they  may 
be  accommodated  by  the  multiplex  system  if  a  direct  connection  to  the  bus 
controller’s  interrupt  hardware  is  used  to  trigger  a  software  action  in 
response  to  the  signal . 

10.9  High  reliability  reoulrements .  The  use  of  simple  parity  for  error 
detection  within  the  multiplex  bus  system  was  dictated  by  a  compromise  between 
the  need  for  reliable  data  transmission,  system  overhead,  and  remote  terminal 
simplicity.  Theoretical  and  empirical  evidence  indicates  that  an  undetected 
bit  error  rate  of  10"^^  can  be  expected  from  a  practical  multiplex  system  built 
to  this  standard.  If  a  particular  signal  requires  a  bit  error  rate  which  is 
better  than  that  provided  by  the  parity  checking,  then  it  is  inoimbent  upon  the 
system  designer  to  provide  the  reliability  within  the  constraints  of  the 
standard  or  to  not  include  this  signal  within  the  multiplex  bus  system.  A 
possible  approach  in  this  case  would  be  to  have  the  signal  source  and  sink 
provide  appropriate  error  detection  and  correction  encoding/decoding  and  employ 
extra  data  words  to  transfer  the  information.  Another  approach  would  be  to 
partition  the  message,  transmit  a  portion  at  a  time,  and  then  verify  (by 
interrogation)  the  proper  transfer  of  each  segment. 

10.5  Stubbing.  Stubbing  is  the  method  wherein  a  separate  line  is  connected 
between  the  primary  data  bus  line  and  a  termifial .  The  direct  connection  of  a 
stub  line  causes  a  mismatch  which  appears  on  the  waveforms.  This  mismatch  can 
be  reduced  by  filtering  at  the  receiver  and  by  using  bl-phase  modulation. 

Stubs  are  often  employed  not  only  as  a  convenience  in  bus  layout  but  as  a  means 
of  coupling  a  unit  to  the  line  in  such  a  manner  that  a  fault  on  the  stub  or 
terminal  will  not  greatly  affect  the  transmission  line  op)eration.  In  this 
case,  a  network  is  employed  in  the  stub  line  to  provide  isolation  from  the 
fault.  These  networks  are  also  used  for  stubs  that  are  of  such  length  that  the 
mismatch  and  reflection  degrades  bus  operation.  The  preferred  method  of 
stubbing  is  to  use  trsuisformer  coupled  stubs,  as  defined  in  9.5. 1.5.1.  This 
method  provides  the  benefits  of  DC  isolation,  increased  common  mode  protection, 
a  doubling  of  effective  stub  Impedance,  and  fault  isolation  for  the  entire  stub 
and  terminal.  Direct  coupled  stubs,  as  defined  in  9.5.  1.5.2  of  this  standard, 
should  be  avoided  if  at  all  possible.  Direct  coupled  stubs  provide  no  DC 
isolation  or  common  mode  rejection  for  the  terminal  external  to  its  subsystem. 
Further,  any  shorting  fault  between  the  subsystems  internal  isolation  resistors 
(usually  on  a  circuit  board)  and  the  main  bus  Junction  will  cause  failure  of 
that  entire  bus.  It  can  be  expected  that  when  the  direct  coupled  stub  length 
exceeds  1.6  feet,  that  it  will  begin  to  distort  the  main  bus  waveforms.  Note 
that  this  length  includes  the  cable  runs  internal  to  a  given  subsystem. 
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10.6  Ose  or  broaOcasl  optiori .  The  use  nf  .i  broadeasL  message  as  defined  in 
i|.  3. 3.6.7  of  this  standard  represents  a  slgrufTcant  departure  from  the  basic 
philosophy  of  this  standard  in  that  it  is  a  ities.sage  format  wtiich  does  not 
provide  positive  closed-loop  control  of  tius  traffic.  The  system  designer  is 
strongly  encouraged  to  solve  any  design  problems  through  ttie  use  of  the  three 
basic  message  formats  without  resorting  to  use  of  the  broadcast.  If  system 
designers  do  choose  to  use  the  broadcast  command,  they  should  carefully 
consider  the  potential  effects  of  a  missed  broadcast  message,  and  the 
subsequent  implications  for  fault  or  error  recovery  design  in  the  remote 
terminals  and  bus  controllers. 
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PREFACE 


This  document  Is  the  revised  MlL-STD-1 589B  Draft  (USAF)  definition 
of  the  upgraded  J73  JOVIAL  programming  language.  The  sections  are 
organized  in  a  top-down  manner.  The  first  section  describes  the 
Interactions  between  the  modules  of  the  complete  program  so  that  In 
subsequent  sections  the  structures  of  the  language  can  be  described  (to 
the  extent  possible)  without  reference  to  their  interaction  with  other 
St  ructures . 

Most  sections  are  divided  Into  separate  parts  entitled  "Syntax," 
"Semantics,"  and  "Constraints."  The  "Syntax"  descriptions  define  the 
grammar  of  the  language  In  a  modified  BNF  notation.  The  "Semantics" 
discussions  define  the  moaning  of  constructs  that  satisfy  the  Syntax  and 
Constraints.  The  "Constraints"  discussions  enumerate  non-syntactic 
requirements  that  must  be  met  In  order  for  the  given  constructs  to  be 
legal.  The  Intent  is  that  the  Syntax,  Semantics,  and  Constraints  not  be 
redundant  with  each  other  -  e.g.,  the  Semantics  sections  do  not  normally 
repeat  something  that  should  be  obvious  from  the  Syntax,  neither  do  they 
repeat  stipulations  that  are  listed  as  Constraints. 

Some  of  the  designated  Constraints  apply  at  compile  time,  and 
others  pertain  to  errors  that  are  not  detectable  until  the  compiled 
program  is  executed.  In  order  to  conform  to  this  standard,  a  J73 
compiler  must  detect  complle-tlrae  errors,  but  It  Is  not  required  to 
generate  code  for  run-time  checks. 

The  Appendix  provides  a  cross-reference  index  to  constructs  that 
appear  in  the  Syntax.  For  each  construct,  the  Index  gives  the  number  of 
the  section  where  that  construct  is  defined  and  the  numbers  of  the 
sections  where  that  construct  is  used  in  a  definiton. 

The  following  metalanguage  conventions  have  been  observed  In  this 
document : 

1.  Terminal  symbols,  l.e.,  those  which  actually  appear  In  a 
program  are  written  In  upper  case.  For  example: 

BEGIN 

END 

STATIC 

2.  Non-terminal  symbols,  l.e.,  those  which  represent  groups  of 
terminal  symbols  are  written  In  lower  case  and  enclosed 
between  <  and  >.  If  any  non-terminal  symbol  Is  longer  than 
one  word,  the  words  are  separated  by  a  hyphen.  For  example: 


111 
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<conipool-inodule> 

<ordlnary-table-body> 

3.  The  following  special  symbols  are  used  In  the  metalanguage. 

: :=  means  "Is  defined  as."  For  example, 

<a>  ::=  <b>  <c> 

where  <a>  is  defined  as  the  string  <b>  followed  by 
the  string  <c>.  Definitions  that  do  not  fit  on  one 
line  may  extend  to  the  next  line  or  lines. 

I  The  I  symbol  Indicates  that  what  follows  is  an 

alternate  choice  of  definition  for  the  non-terminal 
to  the  left  of  the  : symbol.  For  example, 

<a>  ::=  <b>  |  <c> 

where  <a>  is  defined  as  either  the  string  <b>  or 
the  string  <c>. 

(  J  If  a  string  may  optionally  be  present,  it  Is 

enclosed  between  (  and  ].  For  example, 

<a>  l<b>)  <c> 

where  <a>  Is  defined  as  either  the  string  <c>  or 

the  string  <b>  followed  by  the  string  <c>. 

4.  The  following  symbols  have  metalinguistic  meaning  when 
appended  to  a  non-terminal: 

...  One  or  more  instances  of  the  string  represented  by 
non-t  erminal 

,...  One  or  more  Instances  separated  by  a  comma 
:...  One  or  more  Instances  separated  by  a  colon 
For  example: 

<a>...  Represents  a  single  <a>  or  any  sequence  of  <a>'s 
(e.g.,  <a>  or  <a>  <a>  or  <a>  <a>  <a>  <a>  etc.) 

[<a>...]  Represents  the  null  string  or  any  sequence  of  <a>'s 

<a> ,  . . .  Represents  a  single  <a>  or  any  length  sequence  of 

<a>'s  separated  by  commas  (e.g.,  <a>  or  <a>,<a>  or 
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<a>,<a>,<a>  etc.) 

5.  If  a  non-terminal  appearing  on  the  right  side  of  the  : Is 
not  defined  In  that  same  sub-section,  the  number  of  the 
sub-section  where  It  Is  deflneo  appears  In  parentheses  In  the 
right  margin. 

6.  In  a  "Semantics"  or  "Constraints"  section,  non-terminal 
symbols  are  enclosed  between  <  and  >  when  the  usage  refers  to 
constructs  occurring  In  a  "syntax"  section  or  when  the 
specific  J73  meaning  might  be  confused  with  generalized 
programming  usage. 

Throughout  this  document,  the  symbols  used  for  the  prime,  the 
quotation  mark,  and  a  blank  are  as  follows: 

1 .  Prime 

2.  Quotation  mark  " 


3 


Blank 


space 
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1 .0  GLOBAL  CONCEPTS 
1.1  THE  COMPLETE  PROGRAM 


:  :=•  <niodule> ... 

: <compool-module>  (1.2.1) 

I  <procedure-module>  (1.2.2) 

I  <nialn-program-module>  (1.2.3) 

Semant Ics : 

A  <coo)plete-prograni>  of  the  J73  language  gives  the  complet 
specification  of  a  computational  algorithm  to  be  performed. 
<coinplete-program>  consists  of  a  group  of  one  or  more  <modules>  that  are 
compilable  separately  and  which  may  be  subsequently  bound  together  for 
execution  as  a  unit.  A  <module>  Is  the  smallest  entity  In  the  language 
that  may  be  separately  compiled. 

A  <complete-program>  may  contain  zero  or  more  <compool-modu]es>  and 
zero  or  more  <procedure-raodules> . 

Constraint ; 

A  <complete-prograta>  must  contain  exactly  one  <maln-program- 
module>  . 

Note : 


Syntax; 

<coBp] ete-progran> 
<module> 


A  compiler  may  accept  a  file  containing  more  than  one  <module>,  but 
it  Is  not  required  to  do  so.  If  It  does  accept  such  a  file,  It  must 
process  each  <module>  as  though  It  had  been  submitted  separately. 


1.2  MODULES 

1.2.1  COMPOOL  MODULES 

Syntax; 

(9.0) 

(2.0) 

(9.0) 

1 
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<corapool-module>  START  (<directlve>. . .] 

COMPOOL  <compool-name>  ; 
(<corapool-declaratlon> . . . ] 
[<dl rectlve> . . .] 

TERM 


'T'f' 


«)  < 
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<compool-nanie>  :  <nane>  (ft. 2.1) 
Semantics ; 

<Conpool-nodules>  provide  a  means  of  doclarinp,  data  objects,  types, 
and  subroutines  that  are  to  be  made  external  -  l.e.,  that  are 
potentially  available  to  other  <modules>  In  the  <cor:iplctc-proj.;ram>. 
Another  <nodule>  may  access  the  names  declared  in  a  given 
<compool-module>  by  use  of  a  <conipool-directive>  (see  Section  9.1)  that 
names  the  given  conpool  or  by  use  of  external  declarations  (see  Section 
2.5). 


A  <comi)ool-module>  nay  contain  <compool-d 1 rec t 1 ves>  that  name  other 
<compool-modules> . 

By  appropriate  use  of  <dof-specl f Icat ions>  and  <ref-specif lcatlons> 
within  <compool-declaratlons> ,  a  user  can  control  whether  physical 
allocation  takes  place  within  the  <compool-modul e>  Itself  or  within  the 
accessing  <module>  (sec  Section  2.5). 


1.2.2  PROCKDURE  MOnULES 
Syntax : 

<procedure-module> 


<non-nest ed-suht  out! ne> 


START 

(<declaratlon>. . . )  (2.0) 

( <non-nested-subroot ine>  .  . . ) 

{ <dl rective> . . . )  (9.0) 

TERM 

( <d 1 rec t ive> . . )  (9.0) 

IDEF)  <subrou t 1 ne-de f 1 nl t i on>  (3.0) 


Semantics  : 

<Procedurc-r.iodules>  provide  a  means  of  separately  compiling 
subroutines  that  specify  portions  of  the  actions  of  the  <complete- 
program> . 

If  a  <subroutlnc-def initlon>  Is  preceded  by  DEF ,  that  subroutine 
nay  be  invoked  from  within  the  <naln-propram-nodule>  or  from  witliin 
another  <proccdure-modu  le> ,  provided  that  the  referencing  module 
contains  an  appropriate  <ref-spoclflcation>  for  the  subroutine  or 
accesses  a  conpool  containing  such  a  specification. 


<Non-ncsted-subroutlnes>  defined  without  a  DEF  nay  be  Invoked  only 
from  within  the  <procedure-module>  or  <maln-program-nodule>  in  which 
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they  are  defined.  Similarly,  all  declarations  In  a  <procedure-niodule> 
apply  only  within  that  <procedure-module>  (unless  they  are 
<external-declaratlon6>  -  see  Section  2.5). 


1.2.3  MAIN  PROGRAM  MODULES 
Syntax ; 

<maln-program-inodule> 


<program-nanie> 

<program-body> 


START  (<directlve>...l 

(9.0) 

PROGRAM 

<program-name>  ; 

(<directlve>  . .  .] 

(9.0) 

<program-body> 

( <non-nested-subroul i ne> . . . ) 

(1  .2.2) 

I <dl rect I ve> .  .  . ) 

(9.0) 

TERM 

<name> 

(8.2.1) 

<statement> 

(^.0) 

BEGIN  [ <dec la  rat Ion>  .  .  . ) 

(2.0) 

<statement> .  . . 

(4.0) 

( <subrout 1 ne-def i ni l i on>  •  . .  ] 

(3.0) 

1 <dl recti ve>  . . .  ] 

(9.0) 

(<label>...)  END 

(4.0) 

Semantics : 


The  body  of  a  <maln-prograni-module>  Is  executed  at  the  start  of  a 
<complete-program>.  When  execution  of  the  body  Is  complete,  execution 
of  the  <coraplete-prograni>  Is  complete.  Unless  the  <complete-program> 
consists  of  a  single  <na ln-prograro-module> ,  the  <ma 1 n-program-module> 
will  contain  one  or  more  <rompool-dl rectlves> ,  references  to 
externally-declared  data,  and/or  calls  of  DEF'd  subroutines  in  other 
modules . 

Declarations  In  a  <maln-program-module>  may  be  external  or 
Internal.  If  a  <non-nes ted-subroutine>  has  a  DEF,  it  may  be  Invoked 
either  locally  or  from  within  a  <procedure-module> ,  provided  that  the 
referencing  module  contains  an  appropriate  <ref-speci f ica t ion>  for  the 
subroutine  or  accesses  a  corapool  containing  such  a  specification.  If  It 
does  not  have  a  DEF,  It  can  be  Invoked  only  from  within  the  module  In 
which  it  Is  defined. 
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Constraints : 


The  <program-body>  must  contain  at  least  one  non-null  statement 
(e.g.,  STOP). 

1.2.4  CONDITIONAL  COMPILATION 

Two  methods  are  provided  for  conditionally  suppressing  generation 
of  object  code  for  portions  of  a  JOVIAL  module. 

The  !SKIP,  IBEGIN,  and  !END  directives  (see  Section  9.2.2)  permit 
almost  complete  suppression  of  processing  of  suppressed  source.  The 
only  processing  done  for  suppressed  source  Is  to  scan  for  the 
terminating  !END  directive.  Therefore  the  suppressed  source  may  contain 
errors  and/or  statements  Incompatible  with  other  module  source  without 
affecting  compilation. 

The  IF  and  CASE  statements  (see  Sections  4.3  and  4.4)  permit 
suppression  of  generation  of  object  code.  Source  for  this  suppressed 
object  code  must  be  correct  since  it  Is  subject  to  the  same  validity 
checks  and  processing  of  directives  as  other  source  code.  Only  code 
that  Is  unconditionally  unreachable  Is  suppressed  so  this  conditional 
compilation  must  produce  the  same  results  as  if  the  code  was  generated. 
Segments  of  code  which  are  unreachable  due  to  values  of  <if-statement> 
<boolean-f ormulas>  or  <case-selector-f ormulas>  which  are 

<compl le-t Ime-f ormulas>  and  which  do  not  contain  <labels>  are  always 
suppressed.  Implementations  may  choose  to  do  a  more  complete  analysis 
and  also  suppress  other  recognized  unreachable  code. 


1 .3  SCOPE  OF  NAMES 

<Procedure-modules>  and  the  <maln-program-module>  can  contain 
subroutines  (l.e.,  procedures  and  functions)  nested  to  any  depth.  Each 
subroutine,  as  well  as  the  <program-body>  and  the  <main-program-module> 
or  <procedure-module>  Itself,  establishes  a  region  or  scope  for  which  a 
name's  declaration  is  active  and  In  which  the  <name>  can  be  used.  The 
scope  of  a  <name>  Is  that  region  of  the  <complete-program>  within  which 
that  <name>  has  a  single  meaning. 

A  name  declared  with  a  DEF  or  REF  (see  Section  2.5)  is  considered 
to  be  external;  all  other  names  are  Internal .  An  external  <name>  can  be 
used  in  any  module  of  the  <complete-program> ,  except  within  a  scope 
containing  an  internal  name  with  the  same  spelling.  An  Internal  name 
can  be  used  only  within  the  subroutine,  <procedure-module> ,  or 
<maln-program-module>  within  which  that  name  Is  declared,  but  not  within 
an  enclosed  scope  containing  a  <narae>  with  the  same  spelling. 
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The  <name>  of  a  subroutine  belongs  to  the  scope  In  which  that 
subroutine  Is  declared  or  defined. 

For  any  given  compilation,  all  names  made  available  from  referenced 
<compool-modules>  (see  Section  9.1),  as  well  as  the  name  of  the  <module> 
being  complied  and  all  <compool-names> ,  belong  to  the  same  scope, 
referred  to  as  compool  scope,  which  Is  considered  to  enclose  the  scope 
established  by  the  <procedure-module> ,  <maln-program-module> -  or 
<compool-module>  being  compiled. 

System-defined  names  (e.g.,  machine-specific  subroutines. 
Implementation  parameters)  belong  to  system  scope,  which  encloses  the 
compool  scope.  Such  names  may  be  redefined  by  the  programmer. 

These  rules  ensure  that  any  two  names  with  the  same  spelling  but 
with  distinct  scopes  are  regarded  as  if  they  were  different  names. 

Constraint^: 

No  two  names  having  the  same  scope  may  have  the  same  spelling. 
(This  constraint  does  not  prevent  two  tables  with  different 
<table-namcs>  to  be  declared  In  the  same  scope  using  the  same 
<table-type-narae> .  See  Sections  2.1.2  and  2.2.) 

No  two  external  names  may  have  the  same  spelling. 

1.4  IMPLEMENTATION  PARAMETERS 
Syntax ; 

<integer-machlne- 

parameter>  BITSINBYTE 

I  BITSINWORD 

I  LOCSlfWORD 

I  BYTEPOS 

(  <con)plle-t  Ime-lnteger-formula>  )  (5.1.1) 

I  BYTESINWORD 
1  BITSINPOINTER 
I  INTPRECISION 


I  FI.OATPRECISION 
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I  FIXEDPRECISION 
I  FLOATRADIX 
1  IMPLFLOATPRECISION 

(  <preclslon>  )  (2. 1.1. 2) 

I  IMPLFIXEDPRECISION 

(  <scale-speclf ier>  ,  (2. 1.1. 3) 

<f ractlon-specJ f ler  )  (2. 1.1. 3) 

I  IMPLINTSIZE 

(  <lnteger-slze>  )  (2. 1.1.1) 

I  MAXFLOATPRECISION 
I  MAXFIXEDPRECISION 
I  MAXINTSIZE 
I  MAX BYTES 
I  MAX BITS 

I  MAXINT  (  <lnteger-size>  )  (Z.l.l'.l) 

I  MININT  (  <lnteger-slze>  )  (2. 1.1.1) 

I  MAXTABLESIZE 
1  MAX STOP 
I  MINSTOP 
I  MAXSIGDIGITS 
I  MINSIZE  ( 

<conipile-tlme-lnteger-fonnula>  )  (5.1.1) 

I  MINFRACTION  ( 

<compl le-time-f lodting-f ormula>  )  (5.1.2) 

I  MINSCALE  ( 

<coniplle-tlme-f loating-formula>  )  (5.1.2) 

I  MINRELPRECISION  ( 

<complle-tline-floatlng-fonnula  )  (5.1.2) 
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<f loat Ing-ma chine- 
pa  rameter> 


<f ixed-machlne- 
parameter> 


:  :=  MAXKLOAT  (  <prpclslon>  ) 

I  MINKI.OAT  (  <prerlslon>  ) 

I  FLOATRELPRFX’ISION 
(  <precislon>  ) 

I  FLOATUNDERFLOW 
(  <preclslon>  ) 

: MAXFIXED  (  <scale-speci f 1 er> 
<fraction-spfrci f ler>  ) 

I  MINFIXED  (  <srale-specl f i er> 
<fraction-speoi f ier>  ) 


Semant 1 cs : 


(2.1 .1 .2) 
(2.1.1 .2) 

(2.1 .1 .2) 

(2.1  .1.2) 

(2,1 .j .3) 
(2.1  .1  .3) 

(2,1 .1.3) 
(2.1 .1  .3) 


The  machine  on  which  a  J73  program  runs  contains  an  array  of  memory 
cells.  These  cells  are  grouped  or  partitioned  into  the  following  units 
for  purposes  of  the  language  specification. 


1.  PSL  ~  smallest  unit  of  storage  (can  contain  one  of  two 

values,  which  are  represented  by  zero  and  one) 

2.  Byte  -  A  group  of  one  or  more  consecutive  bits  that  is  capable 
of  holding  a  single  character  of  information 

3.  Word  -  A  memory  partition  of  one  or  more  consecutive  bits  that 
serves  as  the  unit  of  allocation  of  data  storage 

Address  Unit  -  The  machine  dependent  unit  used  to  identify  an 
address  or  location  in  memory 

The  number  of  bits  per  byte,  word,  and  address  varies  from 
implementation  to  Implementation,  and  these  quantities  affect  the 
representation  and  behavior  of  data  in  the  language.  Machine  parameters 
are  constants  that  describe  these  Implementation-dependent  differences. 
The  values  of  these  constants  must  be  specified  as  part  of  the 
implementation  of  a  J73  compiler  on  any  computer.  These  names  can  then 
be  referenced  by  a  user  to  access  the  values  associated  with  that 
implementation. 

The  size  of  an  <lnteger-machlne-parameter>  is  the  size  of  an 
<1 nt eger-1 1 tera 1>  having  that  value.  The  attributes  of  a  <floating- 
machlne-parametor>  or  <f 1 xed-machi ne-parame t er>  are  as  specified  by  its 
<preclslon>  or  its  <sca 1 e-specl f 1 er>  and  <f raci 1  on-sped f 1 er> .  The 
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values  of  the  Implementation  parameters  are  as  follows: 


BITSINBYTE 

Numher  of  bits  In  a  byte 

BITSINWORD 

Number  of  bits  In  a  word 

LOCSINWORD 

Number  of  locations  (address  units) 
In  a  word 

BYTEPOS(PP) 

A  permitted  <Btartlng-blt>  value  for 
character  strings  that  cross  word 
boundaries.  PP  Is  any  Integer  value 
between  0  and  BYTESINWORD-1 , 
Inclusive  and  BYTEPOS(PP)  < 
BYTEP0S(PP+1) . 

BYTESINWORD 

Number  of  complete  bytes  In  a  word 

BITSINPOINTER 

Number  of  bits  used  for  a  pointer 
value 

INTPRECISION 

The  number  of  bits  that  an 
Implementation  supplies  to  hold  the 
value  of  an  integer  item  (exclusive 
of  sign,  if  any)  when  no 
<lnteger-slze>  is  specified  by  the 
programmer. 

FLOATPRECISION 

The  number  of  bits  that  an 
Implementation  supplies  to  hold  the 
value  of  the  mantissa  of  a  floating 
point  item  (exclusive  of  the  sign 
bit)  when  no  <precision>  Is  specified 
by  the  programmer 

FIXEDPRECISION 

The  number  of  bits  that  an 
Implementation  supplies  to  hold  the 
value  of  a  fixed  Item  (exclusive  of 
the  sign  bit)  when  no  <fractlor.- 
specifier>  Is  supplied  by  the 
programmer 

FLOATRADIX 

Base  of  the  floating  point 
representation,  specified  as  an 
integer 

IHPLFLOATPRECISION(II) 

Number  of  bits  (not  including  the 
sign  bit)  in  the  mantissa  of  the 
representation  for  a  floating  point 
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value  whose  specified  precision  Is  II 

IMPLFIXEoPRECISION(SS,FF)  The  number  of  bits  (excluding  sign 

bit)  an  Implementation  uses  to 
represent  an  unpacked  fixed  Item  with 
scale  SS  and  fraction  FF.  This  value 
also  determines  the  accuracy  of  fixed 
formula  results. 


IMPLINTSIZE(II) 


MAX FLOATPRECl SION 


MAXFIXEDPRECISION 


MAXINTSIZE 


MAXBYTES 


MAXBITS 


MAXINT(SS) 

MININT(SS) 


The  number  of  bits  (excluding  sign 
bit)  an  Implementation  uses  to 
represent  an  unpacked  S  or  U  Item 

with  specified  size  II. 

Maximum  specifiable  precision 

supported  by  an  implementation  for  a 
<f loating-I tom-descriptlon> 

Maximum  value  supported  by  an 

implementation  for  the  sum  of  the 
scale  and  fraction  specifiers  In  a 
<f ixed-1 1 em-desc  r 1 pt i on> 

Maximum  specifiable  size  (not 

including  the  sign  bit)  supported  by 
an  Implementation  for  signed  and 
unsigned  integers 

Maximum  value  supported 

implementation  for 

<character-size>;  must  not 
MAXBITS/BITSINBYTE 

Maximum  value  supported  by  an 

implementation  for  a  <bit-size>;  the 
maximum  value  of  words  per  entry  in  a 
table  is  MAXBITS/BITSINWORD,  and  the 
maximum  BITSIZE  of  a  table  entry  is 
MAXBITS 

Maximum  integer  value  representable 
in  SS+1  bits  (including  sign  bit) 

Minimum  signed  integer  value 
representable  in  SS+1  bits  (including 
sign  bit),  using  the  implementation's 
method  of  representing  negative 
numbers 


by  an 
a 

exceed 
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MAXTABLESIZE  The  maximum  number  of  words  an 

Implementation  permits  a  table  to 

occupy . 

MAXSTOP  Maximum  specifiable  value  for  an 

<lnteger-formula>  In  a  <stop- 

statement>  (see  Section  4.9) 

MINSTOP  Minimum  specifiable  value  for  an 

<int eger-f ormula>  in  a  <stop- 

statement>  (see  Section  4.9) 

MAXSIGDIGITS  The  maximum  number  of  significant 

digits  an  implementation  vlll  process 
for  a  fixed  or  floating  point  literal 
(see  Section  8.3.1) 

MINSIZE(II)  The  minimum  value  of  SS  such  that  II 

Is  less  than  or  equal  to  MAXINT(SS) 
and  greater  than  or  equal  to 
MININT(SS) 

MINFRACTION(AA)  The  minimum  value  of  FF  such  that 

2**(-FF)  Is  less  than  or  equal  to  AA. 
The  value  of  AA  must  be  greater  than 
zero. 

MINSCALE(AA)  The  minimum  value  of  SS  such  that 

2**SS  Is  greater  than  AA.  The  value 
of  AA  must  be  greater  than  zero. 

MINRELPRECISION(FF)  The  minimum  value  of  PP  such  that 

FLOATRELPRECISION(PP)  Is  less  than  or 
equal  to  FF.  The  value  of  FF  must  be 
greater  than  or  equal  to 

FLOATRELPRFCISION 
(MAX  FLOATPRECI SION). 

MAXFLOAT(PP)  Maximum  floating  point  value  using 

only  the  first  PP  mantissa  bits 
(excluding  sign)  of  the 

implementation's  floating  point 
representation  whose  actual  mantissa 
length  Is  IMPLFLOATPRECISION(PP) .  PP 
must  be  greater  than  zero  and  not 
exceed  MAX FLOATPRECI SI ON. 

MTNFLOAT(PP)  Minimum  floating  point  value 

representable  In  exactly  PP  mantissa 
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bits,  (excluding  sign)  and  using  the 
linpleinentatlon' s  method  of 
representing  negative  numbers,  PP 
must  be  greater  than  zero  and  not 
exceed  MAXFl.OATPRECl  SION. 

Let  FRPl  be  the  smallest  floating 
point  value  greater  than  1 .0  using 
the  first  PP  bits  (excluding  sign)  of 
the  Implementation's  representation 
for  floating  point  values. 
FLOATRELPRECISION(PP)  equals  FRPl  - 
1.0.  PP  must  be  greater  than  zero 
and  not  exceed  MAXFLOATPRECI SION. 

The  smallest  positive  floating  point 
value  using  exactly  PP  mantissa  bits 
(excluding  sign)  and  such  that  both 
FLOATUNDERFLOW(PP)  and 
-FLOATUNDERFLOW(PP)  are  representable 
as  floating  point  values 

Maximum  fixed  value  representable  In 
SS+FF+1  bits  (including  sign  bit) 

Minimum  fixed  value  representable  In 
SS+FF+1  bits  (including  sign  bit), 
using  the  implementation's  method  for 
representing  negative  values 


Note; 

A  FIXEDRADIX  Implementation  parameter  Is  not  provided  since  fixed 
point  values  are  represented  using  radix  2  (see  Section  2. 1.1. 3). 
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2 .0  DECLARATIONS 
Syntax : 

<declaratIon>  <data-declaratlon>  (2.1) 

I  <type-declaratlon>  (2.2) 

I  <subroutlne-declaratlon>  (3.0) 

I  <stateiiient-naine-declaratIon>  (2.3) 

I  <deflne-declaratlon>  (2.4) 

I  <external-dDclaratton>  (2.5) 

I  <overlay-dec]aratlon>  (2.6) 

I  <inllne-declarat ion>  (3.4) 

1  <null-declaration>  (2.7) 

I  BEGIN  <declaratlon> . . . 

END 


I  <dlrective>  <declaratIon>  (9.0) 

<compool-declaratlon>  :  :=  <external-dec]aration>  (2.5) 

I  <constant-dec]aration>  (2.1.3) 

I  <type-declaration>  (2.2) 

I  <def Ine-declarat Ion>  (2.4) 

I  <overlay-declarat ion>  (2.6) 

I  <null-declaration>  (2.7) 

I  BEGIN  <compool-declaratlon>. . . 

END 

I  <directlve>  (9.0) 

<c ompool-d ec 1 a ra t ion> 


Semantics: 

<Dec laratl ons>  associate  <naiiies>  with  programmer-supplied  meanings 
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A  <compool-declarat lon>  Is  a  <declarat lon>  that  appears  In  a 
<conipool-niodule> . 

Constraints 


Except  for  <statement-names> ,  names  of  subroutines,  type  names  In 
<pointer-item-descrlptlons> ,  and  formal  parameter  names,  a  name  may  not 
be  used  prior  to  the  point  at  which  a  <declaratlon>  for  that  name 
appears . 

2.1  DATA  DECLARATIONS 
Syntax; 


<data-declara  t lon> 

::=  <ltera-declaratlon> 

(2.1.1) 

1  <table-declaratlon> 

(2.1.2) 

1  <constant-declaration> 

(2.1.3) 

1  <block-declaration> 

(2.1  .4) 

Semantics ; 

<Data-declarations>  declare  <data-names>  and  their  attributes. 
Three  kinds  of  data  structures  exist  In  J73; 

1.  Item  -  A  simple  data  object  of  the  language.  An  Item  Is  a 
variable  of  a  pre-defined  or  programmer-defined  type  having  no 
constituents. 

2.  Table  -  An  aggregate  data  object  consisting  of  a  collection  of 
one  or  more  items,  or  an  array  of  such  collections.  The 
collection  of  Items  is  called  an  entry.  An  entire  entry  in  a 
table  is  selected  by  the  use  of  the  table  name,  together  with 
a  sequence  of  Indices  ("subscripts")  if  the  table  is  arrayed. 
An  item  within  an  entry  is  selected  by  the  use  of  the  Item 
name  and  the  appropriate  number  of  subscripts. 

3.  Block  -  A  group  of  items  and  tables  and  other  blocks  to  which 
is  allocated  a  contiguous  area  of  storage. 

Additionally,  an  item  or  table  may  be  declared  to  be  CONSTANT,  in 
which  case  its  value  cannot  be  changed  during  execution.  A  constant 
item  must  be  given  an  initial  value  by  means  of  an  <item-preset> . 
Blocks,  items,  or  tables  (other  than  constants)  can  specify,  by  means  of 
an  <allocatlon-specif ier> ,  the  allocation  permanence  of  the  storage 
associated  with  their  names.  Non-constant  items  and  tables  can 
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optionally  be  given  Initial  values  by  means  of  <ltem-preset6>  or 
<table-pre6et6> . 

The  value  of  an  uninitialized  data  object  Is  undefined  until  It 
receives  a  value  In  an  executable  statement. 

Declarations  associate  a  <name>  with  a  type.  A  type  determines  the 
set  of  values  that  an  object  can  have  and  the  operations  that  can  be 
performed  on  those  values.  Types  are  grouped  Into  related  sets  called 
type  classes.  Examples  of  type  classes  are  signed  Integer,  unsigned 
Integer,  float,  and  bit.  Types  within  a  type  class  are  distinguished  by 
the  values  of  certain  properties  known  as  attributes .  For  example,  S  3 
Is  a  particular  type  within  type  class  S  with  a  value  of  3  for  the 
Integer  size  attribute.  Rules  concerning  type  matching  are  found  In 
Section  7.0. 


2.1.1  ITEM  DECLARATIONS 
Syntax ; 


<1  tern-dec la ratlon> 

ITEM  <Item-name> 
(<allocation-speci f ier>] 

<1 tem-type-descrl pt 1 on> 
(<ltem-preset>]  ; 

(2.1.5) 

(2.1.6) 

<I tem-name> 

•  «  a 

<name> 

(8.2.1) 

<I tern- type-de script lon> 

:  :  = 

<lnteger-type-descrl pt lon> 

(2.1  .1  .1) 

1 

<f loatlng-type-descr ipt Ion> 

(2.1  .1 .2) 

1 

<f ixed-type-descrlpt lon> 

(2.1.1 .3) 

1 

<blt-type-descr ipt ion> 

(2.1 .1 .4) 

1 

<character-type-descrlpt ion> 

(2.1  .1  .5) 

1 

<status-type-descript lon> 

(2.1  .1.6) 

1 

<polnter-type-descr Ipt lon> 

(2.1  .1 .7) 

Semantics ; 

<Item-declaratlons>  declare  Items.  Items  are  used  as  variables  to 
retain  values  in  a  J73  program.  Allocation  for  Items  declared  In 
<ltem-declaratlons>  will  be  such  that  no  Items  share  a  word. 
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The  <1  teni-type-descrlptlon>  establishes  the  type  of  an  Item. 

The  <al loca t 1 on-speclf 1 er>  establishes  the  allocation  permanence  of 
Items  which  are  not  enclosed  In  blocks.  This  allocation  permanence  is 
automatic  If  the  declaration  is  in  a  subroutine  and  the 
<allocatlon-specl fler>  is  omitted,  otherwise  It  is  STATIC  (see  Section 
2.1.5).  Items  enclosed  In  blocks  Inherit  the  allocation  permanence  of 
the  enclosing  block. 

The  <ltem-preset> ,  if  present,  specifies  an  initial  value  for  the 

item. 


Constraints ; 

Only  items  having  STATIC  allocation  (explicitly  or  by  default)  may 
contain  an  <1 tera-preset> . 

Declarations  of  items  that  are  <formal-lnput-parameters>  or 
<formal-output-parameters>  (see  Section  3.3)  must  not  contain  an 
<allocation-speclf ier>  or  <1 tem-preset> . 


An  <1 tem-declarat ion>  within 
<allocatlon-specif ier> . 


a  block  must  not  contain  an 


2. 1.1.1  INTEGER  TYPE  DESCRIPTIONS 


Syntax; 

<lntege  r-type- 
description> 


<lnteger-item- 
descrlpt ion> 


<int  eger-slze> 


:  ;=  <Integer-l tem-descrlption> 

I  <integer-type-narae> 

:  :=  S  [ <round-or-t runcate> )  (2. 1.1. 2) 

[<integer-size>] 

I  U  [ ''round-or-t  runcate>  ]  (2. 1.1. 2) 

[■'.  ■.  ';er-size>) 

...omj  ■.-t.lme-integer-formula>  (5.1.1) 


<lnteger-type-name>  :  :=  <I tem'type-name> 


(2.2) 


Semantics : 


An  <lnteger-type-descrlptlon>  is  used  to  specify  a  signed  integer 
type  or  an  unsigned  Integer  type.  S  specifies  a  signed  integer  type;  U 
specifies  an  unsigned  Integer  type. 
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The  <lnteger-slze>  attribute  specifies  the  minimum  number  of  bits 
of  storage  required  to  hold  the  maximum  value  of  the  integer  (excluding 
the  sign,  if  any).  If  <lnteger-slze>  Is  omitted,  It  defaults  to 
INTPRECISION.  The  number  of  bits  allocated  for  signed  Integers  will  be 
at  least  <lnteger-slze>+l ,  and  for  unsigned  Integers  will  be  at  least 
<lntege r-slze> . 

The  value  set  for  a  signed  Integer  type  with  size  SS  Is  MININT(SS) 
through  MAXINT(SS).  The  value  set  for  an  unsigned  Integer  type  with 
size  SS  Is  0  through  MAXINT(SS). 

The  <round-or-truncate>  attribute  specifies  truncation  or  rounding 
Is  to  occur  when  a  value  Is  converted  to  an  Integer  type.  If  R  Is 
specified,  rounding  will  occur.  If  T  Is  specified,  truncation  towards 
minus  infinity  will  occur.  If  Z  Is  specified,  truncation  towards  zero 
will  occur.  If  the  attribute  Is  omitted,  truncation  in  an 
Implementation-dependent  manner  will  occur. 

Constraints  : 

The  maximum  value  that  can  be  specified  for  <lnteger-slze>  Is 
MAXINTSIZE,  an  Implementation  parameter. 

<Integer-slze>  must  be  greater  than  zero. 

An  <lnteger-type-name>  must  be  an  <ltem-type-name>  declared  in  an 
<1  tem-type-declaratlon>  that  contains  an  <integer-type-descript ion>  (see 
Section  2.2). 

Notes ; 

An  implementation  may  choose  MAXINTSIZE  >  BlTSINWORD-1 . 

The  <roond-or-truncate>  option  has  a  use  only  when  an 
<lnteger-l tem-descriptlon>  Is  used  in  an  <integer-converslon>  (see 
Sect  ion  7.0). 


2. 1.1. 2  FLOATING  TYPE  DESCRIPTIONS 


Syntax: 

<floatlng-type-descriptlon> 

<f loatlng-ltem-descrlptlon> 


<floatlng-item-descriptlon> 

<f loatlng-type-name> 

F  [<round-or-truncate>l 
(<preclsion> ) 


p 


MIL-STD-1589B  (USAF) 
06  June  1980 


<round-or-truncate>  : ,  R 

I  .  T 

I  .  z 

<preclsion>  <complle-tinie-lnteger-fonnula>(5.1  .1) 

<f loatlng-type-name>  : <itein-type-name>  (2.2) 

Semantics : 


A  <floatlng-type-descrlptlon>  Is  used  to  specify  a  floating  type. 
The  <preclslon>  attribute  specifies  the  minimum  number  of  bits  of 
storage  required  to  hold  the  value  of  the  mantissa.  If  <precl6lon>  Is 
omitted,  It  defaults  to  FLOATPRECI SION,  an  Implementation  parameter. 

The  <round-or-truncate>  attribute  is  used  to  specify  whether 
truncation  or  rounding  Is  to  occur  when  a  value  of  a  floating  type  with 
a  greater  <preclslon>  is  assigned  to  an  item  of  this  ype.  If  R  is 
specified,  rounding  will  occur.  If  T  is  specified,  iruncatlon  towards 
minus  Infinity  will  occur.  If  Z  is  specified,  truncation  towards  zero 
will  occur.  If  the  attribute  Is  omitted,  truncation  In  an 
Implementation-dependent  manner  will  occur.  Rounding  and  truncation 
take  place  with  respect  to  the  implemented  precision  of  the  floating 
type.  (Note:  IMPLFLOATPRECISION(PP)  Is  an  implementation  parameter 
defining  what  precision  is  provided  when  precision  PP  is  specified.) 

The  value  set  for  a  floating  type  with  <precision>  PP  is 
MINFLOAT(PP)  through  -FLOATUNDERFLOW(PP) ,  0,  and  FLOATUNDF,RFLOW(PP) 
through  MAXFLOAT(PP) . 

Const  raints : 


The  maximum  value  that  can  be  specified  for  <preclsion>  Is 
MAXFLOATPRECISION,  an  Implementation  parameter. 

<Preclsion>  must  be  greater  than  zero. 

A  <f loatlng-type-name>  must  be  an  <ltem-type-name>  declared  in  an 
<1 tem-ty pe-declarat lon>  that  contains  a  <f loat ing-type-descriptlon>  (see 
Section  2.2). 

Note : 


Since  a  <f loatlng-type-descrlptlon>  specifies  only  the  minimum 
precision  required,  an  Implementation  Is  free  to  support  only  one  or  two 
levels  of  Implemented  precision.  Which  implemented  precision  level 
represents  a  floating  type  depends  on  the  value  of  the  specified 
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precision.  The  Implemented  precision  must  never  be  less  than  the 
specified  precision.  Since  an  Implementation  may  provide  more  than  the 
specified  precision,  It  Is  consistent  to  round  or  truncate  a  represented 
value  only  If  converting  from  a  longer  to  a  shorter  implemented 
prec I s Ion . 

2. 1.1. 3  FIXED  TYPE  DESCRIPTIONS 
Syntax : 

<flxed-type-descrlptlon>  : :=  <f lxed-ltem-descrlptlon> 

I  <f ixed-type-name> 

<f 1 xed- 1 1 em-de sc r 1 p 1 1 on>  : :=  A  [ <round-or- 1 runca t e> ]  (2. 1.1. 2) 

<scale-specl f 1 er> 

(,  <f  ract  1  on-sped  f  i  er>) 

<scale-specl f ier>  : <compl le-t lme-1 nt eger-f ormul a>( 5 . 1 . 1 ) 

<f ract 1 on-s pec  1 f 1 er>  ::=  <complle-t Irae-lnt eger-f ormulaX 5 . 1 . 1 ) 

<f ixed-t ype-name>  ::=  <1 tera-type-name>  (2.2) 

Semant 1 cs ; 

A  <f lxed-type-descrlptIon>  Is  used  to  specify  a  fixed  point  numeric 
type.  If  SS  is  the  value  of  the  <scale-specif icr>  and  FF  is  the  value 
of  the  <f  ract  Ion -sped  f  1  er> ,  then  SS-tFF  Is  the  minimum  number  of  bits  In 
the  representation,  excluding  the  sign  bit.  When  SS  and  FF  are  both 
positive,  SS  specifies  the  number  of  bits  to  the  left  of  the  binary 
point  (excluding  the  sign  bit)  and  FF  the  minimum  number  of  bits  to  the 
right  (see  Note  below).  When  SS  is  negative,  the  binary  point  is 
assumed  to  be  ABS(SS)  bits  to  the  left  of  the  first  (non-sign)  bit  of 
the  representation.  Similarly,  when  FF  is  negative,  the  least 
significant  bit  of  the  representation  is  no  more  than  ABS(FF)  bits  to 
the  left  of  the  binary  point. 

The  (nominal)  precision  of  a  fixed  point  type  is  the  sum  of  Its 
scale  and  fraction  specifier.  The  Implemented  precision  may  be  greater 
than  the  nominal  bits  required.  If  <fractIon-specitier>  is  omitted,  the 
fixed  point  type  has  a  default  precision  given  by  FIXEDPRECISION,  an 
implementation  parameter,  and  the  Implied  value  of  the  omitted 
<f raction-speclf ler>  Is  FIXEDPRECISION-SS,  where  SS  Is  the  <scale- 
specifler> . 

If  FF  Is  a  fixed  point  Item  declared  with  a  default 
<fraction-speclfler>,  then  FIXEDPRECISION  =  B1TSIZE(REP(FF))-1 . 
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The  <round-or-truncate>  attribute  epeclfles  truncation  or  rounding 
Is  to  occur  when  a  value  Is  converted  to  a  fixed  point  type.  If  R  le 
specified,  rounding  will  occur.  If  T  Is  specified,  truncation  towards 
minus  Infinity  will  occur.  If  Z  Is  specified,  truncation  towards  zero 
will  occur.  If  the  attribute  Is  omitted,  truncation  In  an 
Implementation-dependent  manner  will  occur.  Rounding  and  truncation 
take  place  with  respect  to  the  Implemented  precision  of  the  fixed  type 
(see  Note  below). 

The  value  set  of  a  fixed  point  type  with  scale  SS  and  fraction  FF 
Is  MINF1XED(SS,FF)  through  MAXFIXED(SS,FF) . 

Constraints : 


The  sum  of  the  scale  and  fraction  specifiers  (l.e.,  the  nominal 
precision)  must  be  greater  than  zero  and  must  not  exceed 
MAXFIXEDPRECISION,  an  Implementation  parameter. 

The  value  of  <scale-specif ler>  must  lie  in  the  range  -127  through 

+  127. 


A  <f lxed-type-name>  must  be  an  <1 tem-type-name>  declared  In  an 
<1 tem-type-decla ra t lon>  that  contains  a  <f lxed-type-descrlption>  (see 
Section  2.2). 

Notes : 


The  set  of  exactly  representable  fixed  point  values  is  determined 
by  a  fixed  type's  scale  and  fraction  specifiers.  A  <fraction- 
specifler>  value,  FF,  means  fixed  point  values  must  be  represented  with 
a  precision  greater  than  or  equal  to  2**(-FF).  A  <scale-speclf ier> 
value,  SS,  means  the  maximum  representable  value  is  at  least  2**SS  - 
2**(-FF)  and  less  than  2**SS. 

An  implementation  is  permitted  to  support  more  than  one  level  of 
Implemented  precision  for  fixed  point  types.  For  computational 
purposes,  values  will  be  represented  using  the  smallest  implemented 
precision  level  (e.g.,  one  word  or  two  words)  consistent  with  the 
value's  nominal  precision.  For  storage  purposes  In  packed  tables,  a 
fixed  point  value  need  occupy  no  more  than  the  number  of  bits  specified 
by  the  nominal  precision  plus  one  bit  for  the  sign. 

IMPLFIXEDPRECISION(SS,FF)  is  an  Implementation  parameter  defining 
what  precision  Is  provided  for  an  unpacked  fixed  point  item  when  nominal 
precision  SS+FF  is  specified.  In  addition,  the  implemented  precision  of 
a  packed  Item  (l.e.,  an  Item  In  a  specified  table,  packed  ordinary 
table,  or  a  tight  table)  as  well  as  an  unpacked  item  is  given  by 
BITSIZE(REP(FI))-1 ,  where  FI  is  the  fixed  point  item. 
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The  implemented  precision  of  a  fixed  item  is  the  number  of  bits 
(excluding  sign  bit)  used  to  store  the  item.  Assignments  to  such  items 
round  or  truncate  with  respect  to  this  precision,  which  is  never  less 
than  the  specified  precision.  Rounding  or  truncation  can  change  a  fixed 
point  value  only  if  the  implemented  precision  is  shortened. 

It  should  be  noted  that  specifying  R,  T,  or  Z  in  an  item 
declaration  only  affects  the  conversion  of  literal  values  (see  Section 
8.3.1)  and  assignments  of  fixed  point  values  when  the  stored 
representation  of  the  value  is  shorter  than  the  representation  used  for 
computations . 


2. 1.1. 4  BIT  TYPE  DESCRIPTIONS 


Syntax; 


<bl t- type-descr ipt lon> 

<bl t-1 tem-descriptlon> 
<blt-slze> 
<blt-type-name> 
Semantics : 


: ;=  <blt-ltem-descriptlon> 

I  <blt-type-name> 

; :=  B  [<blt-size>] 

: :=  <complle-t lme-integer-formula>  (5.1.1) 
:  <item-type-name>  (2.2) 


A  <blt-type-descrlptlon>  Is  used  to  specify  a  bit  string  type.  The 
<blt-size>  attribute  specifies  the  number  oi  bits  in  the  string.  If 
<blt-slze>  is  omitted  it  defaults  to  1. 


Constraints : 


The  maximum  value  that  can  be  specified  for  <bit-slze>  is  MAXBITS, 
an  implementation  parameter.  The  minimum  value  that  can  be  specified 
for  <blt-slze>  is  one. 

A  <blt-type-name>  must  be  an  <1 tem-type-name>  declared  in  an 
<ltem-type-declaration>  that  contains  a  <blt-type-descrlption>  (see 
Section  2.2). 
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2. 1.1. 5  CHARACTER  TYPE  DESCRIPTIONS 


Syntax ; 

<character-type-descrlptlon> 

) 

<character-lteni-descrlptlon>  ::  = 
<character-slze>  :  :  = 

<character-type-name>  :  :  = 

Semantics : 


<character-ltem-descrlpt lon> 
<character-type-name> 

C  ( <character-slze> ] 

<compl  le-t  lme-1  nt  eger-f  orniula>(5 .1.1) 
<ltem-type-name>  (2.2) 


A  <character-type-desc riptlon>  Is  used  to  specify  a  fixed-length 
character  string  type.  The  <character-size>  attribute  specifies  the 
number  of  characters  In  the  string.  If  <cbaracter-size>  Is  omitted  it 
defaults  to  1 . 

Constraints : 


The  maximum  value  that  can  be  specified  for  <character-slze>  Is 
KAXBYTES,  an  implementation  parameter.  The  minimum  value  that  can  be 
specified  for  <character-slze>  Is  one. 

A  <character-type-narae>  must  be  an  <1 tem-type-name>  declared  in  an 
<item-type-declaratlon>  that  contains  a  <cbaracter-type-descrlpt lon> 
(see  Section  2.2). 

2. 1.1. 6  STATUS  TYPE  DESCRIPTIONS 


Syntax; 

<status-type-description> 

<s tatus-1 tem-descript ion> 

<status-li6t> 


=  <status-item-descriptlon> 

I  <status-type-name> 

=  STATUS  l<status-slze>l 
(  <status-llst>  ) 

=  <default-sublist> 

I  [<default-subllBt>  ,) 
<specifled-sublist>  , . . . 
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<default-subll 6t> 

: 

<status-constant> , . . . 

<speclf Ied-subll6t> 

; 

<statu6-ll 6t-lndex> 

<status-constant> , . . . 

<statu6-llst-lndex> 

= 

<compIle-time-lnteger-f ormula> 

(5.1.1) 

<status-con6tant> 

:  := 

V  (  <status>  ) 

<s  tatus> 

:  ;  = 

<name> 

(8.2.1) 

1 

<letter> 

(8.1) 

1 

<reserved-word> 

(8.2.2) 

<status-type-name> 

•  •  a 

•  • 

<1 tem-type-name> 

(2.2) 

<status-slze> 

:  :  = 

<compIle-t Ime-lnteger-f ormula> 

(5.1.1) 

Semantics : 

A  <status-type-i 

descriptlon> 

is  used  to  specify  a  status  type.  The 

<status-list>  is  used 

to  define 

the  value  set  of  the  type. 

which 

consists  of  a  set  of  named  <status-const ants> .  These  named 
<s tatus-constants>  are  considered  to  be  the  logical  values  of  the  status 
type.  Associated  with  each  logical  value  Is  a  representational  value, 
l.e.,  how  the  value  Is  actually  represented  internally.  If  the 
<status-llst>  contains  only  a  <def ault-sublist> ,  the  status  type  is  said 
to  have  a  default  representation.  The  <status-constants>  in  the 
<default-sublist>  will  be  assigned  representational  values  0  through  N-1 
(where  N  is  the  number  of  <status-constants>  In  the  sublist)  in  the 
order  in  which  they  are  specified  in  the  list.  The  <status-constants> 
in  each  <specif led-subllst>  will  be  assigned  representational  values 
<status-llst-index>  through  <status-list-index>  +  N-1  (where  N  is  the 
number  of  <status-constants>  In  the  sublist)  in  the  order  in  which  they 
are  specified. 

For  a  given  <statu6-list> ,  the  value  of  any  <st:jLus-constant>  is 
considered  to  be  greater  than  the  value  of  another  <status-constant> 
having  a  lower  representational  value. 

<Status-slze>  specifies  the  minimum  number  of  bits  to  be  allocated 
to  hold  the  status  value  (excluding  the  sign  bit,  if  any).  If  it  is 
omitted,  it  defaults  to  the  minimum  needed  for  the  representation  as  an 
integer  value.  If  the  representation  of  the  lowest-valued 
<status-constant>  In  the  list  Is  less  than  zero,  signed  Integer 
representation  will  be  used;  otherwise,  unsigned  integer  representation 
will  be  used. 
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Constraints : 


The  <status-constants>  must  be  unique  within  the  <status-l ist> . 

The  <status-llst-indlces>  within  a  <status-list>  must  be  specified 
such  that  all  the  <status-constants>  in  the  <status--l ist>  receive  unique 
representational  values. 

The  value  specified  in  <status-slze>  must  be  greater  than  or  equal 
to  the  minimum  needed  for  the  representation  of  the  status  values  and 
less  than  or  equal  to  MAXINTSIZE. 

The  representation  of  a  status  value  cannot  be  less  than  MININT 
(BITSINWORD-1)  and  it  cannot  exceed  MAXINT(BITSINWORD-I) . 

A  <status-type-name>  must  be  an  <ltem-type-name>  declared  in  an 
<ltem-type-declaratlon>  that  contains  a  <status-type-desc r i pt ion>  (see 
Section  2.2). 

Note ; 


The  use  of  a  <name>  In  a  <status>  does  not  constitute  a  declaration 
of  the  <name>  or  a  reference  to  a  declared  <name>  having  the  same 
spelling.  Within  a  given  scope,  a  <status>  <name>  and  a  declared  <name> 
can  have  the  same  spelling  and  no  conflict  will  result. 


2. 1.1. 7  POINTER  TYPE  DESCRIPTIONS 
Syntax : 


<polnter- type-descript lon> 

:  ;=  <pointer-item-descrlptlon> 

1  <pointer-type-name> 

<polnter-l tem-descrlptton> 

;  ;=  P  t<type-name>] 

<polnter-type-name> 

: :=  <ltem~type-name> 

(2.2) 

<type-name> 

; :=  <item-type-name> 

(2.2) 

1  <table-type-name> 

(2.2) 

1  <block-type-name> 

(2.2) 

Semantics : 

A  <polnter-type-descrlptlon>  Is  used  to  specify  a  pointer  type.  If 
the  <polnter-ltem-descrlpt ion>  contains  a  <type-name>,  then  the  pointer 
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being  specified  Is  a  typed  pointer.  If  the  <type-nanie>  Is  cniltted,  then 
the  pointer  Is  an  untyped  pointer. 

A  typed  pointer  contains  the  address  of  a  data  object  of  the  type 
specified  by  the  <type-nanie> .  The  object  being  pointed  to  may  be 
obtained  by  dereferencing  the  pointer  (see  Section  6.1). 

An  untyped  pointer  contains  the  address  of  a  data  objec'  of  any 
type.  However,  such  a  pointer  must  be  converted  to  a  typed  pc^iier  (see 
Section  7.0)  before  It  may  be  dereferenced  or  assigned  :  a  typed 
pointer. 

Constraint : 


A  <polnter-type-name>  must  be  an  <ltem-type-name>  declared  In  an 
<1 tem-type-decla ratlon>  that  contains  a  <polnter-type-descrlption>  (see 
Section  2.2). 

2.1.2  TABLE  DECLARATIONS 
Syntax ; 


<table-declaration>  ;:=  TABLE  <table-name> 


{ <aJlocatl on-spec ifler>) 

( <dimenslon-l 1 s t> ] 
table-descript ion> 

(2.1.5) 
(2.1 .2.1) 

<table-descriptlon> 

::=  I<structure-specifler>] 
<entry-speclf ier> 

(2.1 .2.2) 

1  <table-type-name> 
[<table-preset>]  ; 

(2.2) 

(2.1.6) 

<entry-speclf ier> 

<ordlnary-entry-specif ier> 

(2.1 .2.3) 

1  <speclfled-entry-6pecif ler> 

(2. 1.2. 4) 

<table-name> 

::■=  <name> 

(8.2.1) 

Semantics ; 

<Table-declarations>  declare  named  aggregate  data  objects.  The 
presence  of  a  <dlmenslon-list>  Indicates  that  the  table  is  an  arrayed 
collection  of  entries.  The  <dlmension-llst>  specifies  the  range  of 
indices  of  the  array. 

The  <allocatlon-speclf ler>  establishes  the  allocation  permanence  of 
tables  which  are  not  enclosed  In  blocks.  This  allocation  permanence  Is 
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automatic  if  the  declaration  Is  In  a  subroutine  and  the 
<allocatlon-6peclfler>  Is  omitted,  otherwise  it  Is  STATIC  (see  Section 
2.1.5).  Tables  enclosed  In  blocks  inherit  the  allocation  permanence  of 
the  enclosing  block. 

The  <table-descrlptlon>  describes  the  csntents  of  the  table  either 
with  a  <table-type-name>  (see  Section  2.2)  or  with  an  <entry-speclf ler> . 
Two  or  more  tables  may  be  declared  In  the  same  scope  using  the  same 
<table-type-name> ,  and  no  name  conflicts  of  the  contained  Items  will 
result,  provided  the  <table-names>  are  different.  Items  In  tables 
declared  with  a  <table-ty pe-name>  can  only  be  accessed  using  pointers  to 
the  tables  (see  Section  6.1). 

A  table  may  either  be  an  ordinary  table,  in  which  only  the  logical 
structure  Is  described  (see  Section  2. 1.2. 3)  or  a  specified  table,  In 
which  the  detailed  physical  layout  of  the  table  Is  described  (see 
Section  2. 1.2. A). 

A  <s true t ure-specl f 1 er>  Is  used  to  specify  the  representation  of 
entries  in  a  dimensioned  table  (see  Section  2. 1.2. 2). 

The  <table-preset> ,  If  present,  specifies  Initial  values  for  the 
table  components.  For  <table-descript ions>  containing  an  <entry- 
speclfler>  rather  than  a  <table-type-naroe> ,  the  <table-preset>  Is  part 
of  the  <entry-speclf ler>  (see  Section  2. 1.2. 3  and  2. 1.2. A). 

Constraints ; 

Only  tables  having  STATIC  allocation  (explicitly  or  by  default)  may 
contain  a  <table-preset> . 

Tables  that  are  <formal-lnput-paraineters>  or  <formal-output- 
parameters>  (see  Section  3.3)  must  not  contain  an  <al location-specif ier> 
or  <table-preset> . 

A  <table-declarat ion>  within  a  block  must  not  contain  an 
<allocat Ion-spec If ler> . 

A  dimensioned  <table-declaratlon>  must  not  contain  a  <table-type- 
name>  whose  declaration  also  contains  a  <dlmenslon-llst>. 

A  <structure-speclf ler>  In  an  undimensioned  table  Is  prohibited. 
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<dl mens  Ion-1 is t> 

(  <dlmensIon>, . . .  ) 

<dlmensIon> 

:  :=»  (<lower-bound-optlon>) 

<upper-bound> 

I  * 


<lower-bound-opt lon> 

: :=  <lower-bound>  : 

<lower-bound> 

:  :=  <complle-tliDe-lnteger-forroula> 

(5.1.1) 

1  <complle-tlme-status-f ormula> 

(5. A) 

<uppe  r-bound> 

:  ;=  <compIle-t  Ime-1  nt  eger-f  oniiula> 

(5.1.1) 

1  <complle-tlme-status-formula> 

(5.4) 

Semantics; 

A  <dlmension-l 1 st> 
<dImonsion>  specifies  the 
<lover-bound>  is  omitted, 
integer;  if  the  <upper 
first  <status-constant>  I 

specifies  that  a  table  is  an  array.  Each 
range  of  values  for  that  dimension.  If  the 

it  defaults  to  zero  if  the  <upper-bound>  is  an 
-bound>  is  a  status  value,  it  defaults  to  the 
n  the  status  type  of  the  <upper-bound> . 

A  <dimensIon>  of  * 

that  appears  with  a  formal  parameter 

means  the 

bounds  will  be  determined  from  the  actual  parameter  on  each  Invocation. 
(Note  that  in  accordance  with  Sections  6.3.9  and  6.1,  bounds  of  * 
dimensions  range  from  0  to  NN-1 ,  where  NN  is  the  number  of  elements  in 
the  corresponding  dimension  of  the  actual  parameter,  regardless  of  what 
the  lower  and  upper  bounds  values  are  for  the  actual  parameter  or 
whether  the  bound  has  an  integer  or  status  type.) 

Constraints; 

Only  status  types  with  default  representations  may  be  used  in 
<dlmensions> . 

The  <lower-bound>  must  be  less  than  or  equal  to  the  <upper-bound> . 

The  <lower-bound>  and  <upper-bound>  roust  both  be  status  formulas 
of  the  same  type  or  both  be  Integer  formulas. 

The  maximum  number  of  <dlmensl',iis>  is  seven. 

A  <dlroenslon>  of  *  may  be  used  only  with  a  table  formal  parameter. 

If  any  <dimensIon>  of  a  table  formal  parameter  Is  specified  as  *, 
they  all  roust  be  specified  as  *. 
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The  number  of  words  occupied  by  a  table  must  not  exceed 
MAXTABLESIZE. 


2. 1.2. 2  TABLE  STRUCTURE 
Syntax; 

<structure-speclf ler> 


<blts-per-ent ry> 

Semantics ; 

Dimensioned  tables  can  have  a  parallel  or  serial  structure.  In 
addition,  a  serial  table  may  be  tightly  structured.  The 
<structure-specl f ier>  specifies  the  table  structure. 

A  <structure-speclfler>  PARALLEL  indicates  parallel  structure.  For 
tables  with  parallel  structure,  the  first  word  (word  0)  of  each  entry  is 
allocated  consecutively,  then  word  one,  etc.  An  omitted 
<structure-speclf ier>  or  one  with  T  indicates  serial  structure.  For 
tables  with  a  serial  structure,  all  words  of  the  first  entry  are 
allocated  consecutively,  then  all  words  of  the  next  entry,  etc.  Entries 
In  both  parallel  and  serial  tables  are  arranged  such  that  the  rightmost 
Indices  vary  fastest,  from  the  lower  bound  to  the  upper  bound. 

A  <structure-specifler>  of  T  Indicates  tight  structure  (In  addition 
to  serial  structure).  Tight  structure  defines  the  allocation  of  storage 
between  entries  In  a  dimensioned  (ordinary  or  specified)  table,  whereas 
packing  (see  Section  2. 1.2. 3)  defines  the  allocation  of  storage  wl thin 
an  entry  of  an  ordinary  table.  Tight  structure  indicates  that  multiple 
entries  of  a  dimensioned  table  are  to  be  stored  within  a  single  word 
such  that  no  entry  crosses  a  word  boundary.  <B1 ts-per-entry>  specifies 
the  number  of  bits  each  entry  is  to  occupy.  If  it  Is  omitted.  It  will 
default  to  the  minimum  number  of  bits  needed  to  store  the  entry. 

Entries  In  tightly-structured  tables  are  right- justified  in  the 
bits  allotted. 

Entries  In  tables  without  a  <structure-speci f ler>  of  T  shall  not 
share  a  word. 

Constraints : 


:  :=  PARALLEL 

I  T  (<blts-per-entry>) 

;:=  <compi  le-t  ime-1  nteger-f  ormiila>  (5.1.1) 


<Bits-per-entry>  must  be  equal  to  or  greater  than  the  minimum 
number  of  bits  needed  to  store  the  entry. 
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The  explicit  or  default  value  of  <blt6-per-entry>  oust  be  less  than 
or  equal  to  BITSINWORD. 

Items  In  a  parallel  table  must  not  cross  word  boundaries. 

A  parallel  table  must  contain  a  <dlmenslon-ll6t>. 


2. 1.2. 3  ORDINARY  TABLE  ENTRIES 
Syntax; 

<ordl nary-entry- 


sped  f  ler> 

::=  [<packlng-speclfler>] 

<1 tem-type-descrl pt 1 on> 
[<table-preset> ]  ; 

(2.1  .1) 
(2.1.6) 

1  [<packlng-speclfler>l 
(<table-preset>]  ; 
<ordinary-table-body> 

(2.1.6) 

<packl ng-specif ler> 

:  :=  N 

1  M 

1  D 

<ordlnary-table-body> 

:  :=  <ordlnary-table-ltein-declaratlon> 

1  BEGIN 

<ordlnary-table-optlons> . . . 

END 

<ordl nary- table- 1 tem- 
declaratIon> 

: :=  ITEM  <table-l tem-narae> 
<lteni-type-descrlption> 

I <packlng-speclf ler> ] 
(<table-preset>)  ; 

(2.1.1) 

(2.1.6) 

<table-l tem-name> 

; :=  <name> 

(8.2.1) 

<ordinary-table-optlons> 

;  <ordlnary- 1 abl e- item-dec la  rati on> 

1  <dlrectlve> 

(9.0) 

1  <null-declaratlon> 

(2.7) 
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Semantics; 

An  <ordlnary-entry-speclf ler>  Is  used  to  specify  the  contents  of  an 
entry  of  an  ordinary  table. 

No  allocation  order  Is  Implied  by  the  order  of  items  In  the 
<ordlnary-table-optlons>  unless  the  <ordlnary-table-optlon6>  contains  an 
<order-dlrectlve> .  If  an  <order-dlrectlve>  Is  not  In  effect, 
<ordlnary-table-optlons>  will  be  reordered,  If  necessary,  to  reduce  the 
storage  occupied  by  an  entry,  consistent  with  the  <packlng-speclf ler> . 
Tables  having  the  same  type  will  have  the  same  representation. 

The  <pac'klng-speclf ler>  specifies  the  density  with  which  items  are 
allocated  within  an  entry.  The  following  three  degrees  of  packing  can 
be  specified: 

1.  N  Indicates  that  the  Items  are  not  packed.  No  items  share  a 
word . 

2.  M  Indicates  a  density  of  packing  that  can  be  between  N  and  D. 

The  exact  meaning  is  Implementation-dependent,  and  Is 

specified  to  be  an  effective  compromise  between  space  usage 
and  accessing  ease. 

3.  D  Indicates  dense  packing.  Items  are  allocated  adjacent  bits 
in  a  word  with  the  following  exceptions: 

a.  Non-character  Items  one  word  or  longer  start  on  a 
word  boundary.  Shorter  non-character  Items  do  not 
cross  word  boundaries. 

b.  Each  byte  of  a  character  item  which  crosses  a  word 
boundary  must  be  allocated  on  a  byte  boundary.  An 
Implementation  may  (but  need  not)  allocate  the  bytes 
of  other  character  Items  on  byte  boundaries. 

A  <packing-speclf ler>  preceding  an  <ordinary-table-body>  In  an 
<ordlnary-entry-speclf ler>  applies  to  all  items  In  the  <ordinary- 
lable-hody>  that  do  not  themselves  Include  a  <packing-speclf ler>  In 
their  declaration. 

Default  packing  for  a  tightly-structured  table  (see  Section 
2. 1.2. 2)  Is  D;  for  all  other  tables.  It  Is  N. 

The  value  of  unallocated  bits  In  an  <ordlnary-entry-speclfler>  Is 
Implementation-dependent . 

The  <table-preset> ,  If  present,  specifies  Initial  values  for  the 
table  entries. 
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Constraints : 

Only  tables  having  STATIC  allocation  (Implicitly  or  explicitly)  may 
contain  a  <table-preset> . 

Declaration  of  table  <formal-lnput-parameters>  or 

<formal-output-parameters>  (see  Section  3.3)  must  not  contain 
<table-presets>. 

If  a  <table-preset>  precedes  the  <ordlnary-table-body> ,  none  of  the 
<ordlnary-table-ltem-declaratlons>  In  the  <ordlnary-table-body>  can 
contain  a  <table-preset> . 

An  <ordlnary-entry-speclf ler>  used  In  a  <table-type-declaratlon> 

(see  Section  2.2)  must  not  contain  a  <table-preset> . 

An  <ordinary-table-optlons>  must  contain  at  least  one  <ordlnary- 
table-i tem-declaratlon> . 

A  <packlng-speclfler>  of  N  Is  permitted  In  a  tightly-structured 
table  only  if  the  table  entry  contains  only  one  Item. 

The  number  of  words  allocated  for  a  table  entry  must  not  exceed 
MAXBITS/BITSINWORD. 

2. 1.2. 4  SPECIFIED  TABLE  ENTRIES 


<specl f led-ent  ry- 
speci f ler> 


<wo rds-per-entry> 


<entry-slze> 

<speclf led-ltem- 
desc  ript lon> 


::=  <words-per-entry> 

<specif Ied-item-descriptlon> 
[<table-preset> )  ;  (2.1.6) 

I  <words-per-entry> 

(<table-preset>  ]  ;  (2.1.6) 

<specl f led-table-body> 

: W  ( <entry-slze>] 

I  V 

::=  <complle-tlroe-Integer-formula>  (5.1.1) 

<1  tom-type-descrlptlon>  POS  (2.1.1) 

(  <location-speclfler>  ) 
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<locatIon-speclfler> 

: :=  <start Ing-bi t>  , 

<startlng-word> 

<startlng-blt> 

:  :=  <coinpl  le-t  irae-i  nt  eger-f  ormula> 

i  -k 

(5.1.1) 

<startlng-word> 

1 

:  :=  <complle-l i me-1 nteger-f ormula> 

(5.1.1) 

<speclf led-table-body> 

:  :=  <speci f i ed-t abl e-I tern-dec  la  rat ion> 

1  BEGIN 

<speclfied-table-optlons>  .  .  . 

END 

<speclfled-tallr-ltem- 
declarati  0U/> 

;  :=  ITEM  <t abl e-1 1 ci;i-name> 

<specl f  led-1 1  em-desc  ri pt 1 on> 

[ <t abl  e-prcset> )  ; 

(2.1 .2 .3) 

(2.1.6) 

< s peel f led- tab le> 
options> 

; :=  <specl  f 1 ed-t able- 1 1 em-dec 1  a  ra t ion> 

1  <dlrective> 

(9.0) 

1  <null-declaratlon> 

(2.7) 

Semantics! 

A  <spec 1 f 1 cd-ent ry-specif ier>  is  used  to  specify  the  contents  of  an 
entry  of  a  specified  table. 

<Words-per-entry>  specifies  the  size  of  (I.e,  number  of  words  in) 
each  entry  in  the  table.  <Words-per-ent ry>  containing  a  W  indicates  a 
fixed-length-entry  specified  table  whereas  V  indicates  a 
variable-length-entry  specified  table.  In  a  fixed-length-entry 
specified  table,  <entry-slze>  (if  present)  specifies  the  number  of  words 
allocated  to  each  entry  in  the  table.  In  a  tightly-structured  table  (in 
which  <entry-size>  must  be  omitted),  the  size  of  the  entry  is  determined 
from  the  <structure-specif ler>.  In  a  variable-length-entry  specified 
table,  each  entry  Is  allocated  one  word. 

The  < 1  oca t lon-s peel f ier>  specifies  the  physical  location  of  the 
Item  from  the  start  of  the  entry.  <Start ing-word>  indicates  at  which 
word  of  the  entry,  starting  from  zero,  the  item  Is  to  start,  and 
<start ing-bl t>  Indicates  at  which  bit  in  the  word,  starting  from  zero  at 
the  leftmost  part  of  the  word,  the  Item  is  to  start.  In  the  case  of 
entries  in  tightly  structured  tables,  <starting-blt>  is  considered  to  be 
relative  to  the  start  of  the  entry.  A  <start ing-blt>  of  *  indicates 
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that  the  Item  should  occupy  the  same  amount  of  storage  and  be  aligned  In 
the  same  way  It  would  if  It  were  allocated  outside  a  table,  In  order  to 
ensure  efficient  access  to  the  Item.  These  rules  apply  to  both 
fixed-length-entry  and  to  variable-length-entry  specified  tables. 
Consequently,  In  a  variable-length-entry  table,  reference  to  an  item 
with  subscript  NN  will  reference  that  item  relative  to  the  start  of  the 
NNth  entry,  wliere  each  entry  is  considered  to  be  one  word  long  (l.e.,  a 
subscript  of  NN  does  not  refer  to  the  NNth  logical  entry  In  that  table). 
It  Is  entirely  up  to  the  programmer  to  keep  track  of  the  actual  length 
of  logical  entries  In  such  tables. 

The  <table-preset> ,  If  present,  specifies  initial  values  for  the 
table  entries. 

The  value  of  unallocated  bits  In  a  <spoc I f 1 cd-table-ent ry>  Is 
Implement  at  Ion-dependent . 

Constraints: 


<Entry-slze>  must  be  omitted  on  tightly-structured  tables  and  must 
be  present  otherwise. 

<Entry-slze>  must  be  greater  than  zero  and  less  than  or  equal  to 
MAXBITS/BITSINWORD. 

<Start lng-word>  must  be  non-negative.  For  Items  in  tables  with 
entry  sizes  specified  by  <entry-slze>,  <start lng-word>  plus  number  of 
words  occupied  by  the  item  must  not  exceed  <ent ry-s i ze> .  For  tightly 
structured  tables  <starting-word>  must  be  zero. 

<Startlng-blt>  must  be  non-negative  and  must  not 
position  to  violate  other  positioning  constraints.  For 
structured  tables  it  must  also  be  less  than  BITSINWORD. 
structured  tables  <start ing-bit>  plus  number  of  bits  occupl 
Item  must  not  exceed  <bl ts-per-entry>. 

Only  tables  having  STATIC  allocation  (Implicitly  or  explicitly)  may 
contain  a  <table-preset> . 

Tables  that 

<formal' out  put-pa rameters> 

<table-preset> . 

If  a  <table-preset>  precedes  the  <speclf led-table-body> ,  none  of 
the  <Fpeclfled-table-Item-declaratlons>  In  the  <specif ied-table-body> 
can  contain  a  <table-preset> .  If  any  part  of  an  Item  In  a 
<speclf led-table-body>  overlaps  any  part  of  another  Item  In  the  table 
body,  only  one  of  the  Items  can  be  preset. 


are  <formal-lnput-parameters>  or 

(see  Section  3.3)  must  not  contain  a 


cause  item 
non-tlglitly 
For  tightly 
ed  by  the 
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A  <speclfled-entiy-speclf ier>  used  In  a  <table-type-declaratlon> 
(see  Section  2.2)  must  not  contain  a  <table-preset> . 

A  <6peclf led-table-optlons>  must  contain  at  least  one  <specifled- 
table-ltem-declaratlon>. 

Non-character  Items  whose  size  Is  one  word  or  less  cannot  cross  a 
word  boundary.  Character  Items,  regardless  of  length,  may  start  on  any 
byte  boundary,  l.e.,  any  value  of  the  machine  parameter  BYTEPOS.  Any 
<s t art  1 ng-bl t>  value  Is  permitted  for  character  Items  that  do  not  cross 
word  boundaries. 

An  Implementation  may  restrict  legal  <start Ing-bl t>  values  for 
pointer  Items  that  are  Initialized. 

Va r 1 able-1 ength-ent ry  specified  tables  roust  contain  a 
<specl f led-t abl e-body> ,  and  they  cannot  contain  <table-prosets>  or 
<structure-speclflers>. 


2.1.3  CONSTANT  DECLARATIONS 
Syjv^aj^: 

<cons t a nt-dec 1  a ra t i on>  ::=  CONSTANT  ITEM 

<constant-i t  om-name> 

<1 t em-type-desc rl pt 1 on>  (2.1.1) 

<1  teD)-preset>  ;  (2.1.6) 

I  CONSTANT  TABLE 

<constant-tabl e-naroe> 

( <d imens 1 on-1 1 st> J  (2. 1.2.1) 

<t abl e-dcsc ri pt j on>  (2.1.2) 

<cons t ant-1 tem-narae>  ::=  <name>  (8.2.1) 

<constant-table-name>  : :=  <naroe>  (8.2.1) 

Semant I cs : 


A  <constant-declaration>  creates  an  item  or  table  whose  value  roust 
be  set  by  means  of  an  <1 t em-preset>  or  <table-prcset>  and  whose  value 
cannot  be  changed  during  execution  of  a  program.  The  value  of  a 
constant  Item  whose  type  class  is  not  pointer  can  be  used  in  a 
<corapl le-t ime-formula>  (see  Section  5.0).  The  value  of  a  constant  table 
or  an  Item  within  a  constant  table  may  not  be  used  In  a 
<compi le-t Ime-formul a> . 


33 

87 


AtWAlOO  577  AERONAUTICAL  SYSTEMS  DIV  MRISMT-PATTERSON  AFB  OH  F/6  1/3 

AFSC  STANDARDIZATION  CONFERENCE*  1553*  15®9»  1750*  1760»  ADA*  N-^TC(U) 
NOV  60  E  C  6AN6H*  S  E  SMITH 

UNCLASSIFTFO  ASD-TR-SO-SOSO-VOL^  _  _ 


MIL-STD-1589B  (USAF) 

06  June  1980  | 

Physical  storage  will  be  allocated  for  all  <constant-declaratlons> 
that  are  in  <block-declaratlons>. 

The  allocation  permanence  of  all  allocated  <constant-declaratlon6> 

Is  considered  to  be  STATIC,  even  If  the  declarations  appear  in  a 
<subroutlne-def Inl tlon> , 


2.1. A  BLOCK  DECLARATIONS 


Syntax; 

<block-declarat lon> 


<block-name> 

<block-body-part> 


<block-body-opt lons> 


:  :=»  BLOCK  <block-name> 

[<al location- sped  f  ler>l 
<block-body-part> 

I  BLOCK  <block~name> 

[<al location-spec  if ier>] 
<block-type-name> 
[<block-preset>]  ; 

:  :=  <nan!e> 

: :=  <null-declaratlon> 

I  <data-declaration> 

I  BEGIN 

<block-body-options> . . . 
END 

::=  <data-declaratlon> 

1  <overlay-declaration> 

I  <dlrective> 

1  <nul 1-declarat lon> 


(2.1.5) 

(2.1.5) 

(2.2) 

(2.1.6) 

(8.2.1) 

(2.7) 

(2.1) 

(9.0) 

(2.1) 

(2.6) 

(9.0) 

(2.7) 


Semantics : 


A  <block-declaration>  declares  a  group  of  items,  tables,  and  other 
blocks  that  are  to  be  allocated  in  a  contiguous  area  of  storage.  No 
allocation  order  is  implied  by  the  order  of  the  declarations  within  a 
block  unless  the  <block-body-optlons>  contains  an  <order-dlrective>.  If 
an  <order-dlrective>  Is  not  In  effect,  <bl ock-body-optlons>  will  be 
reordered.  If  necessary,  to  improve  accessibility. 
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The  <allocatlon-specl f ler>  establishes  the  allocation  permanence  of 
blocks  which  are  not  enclosed  In  blocks.  This  allocation  permanence  Is 
automatic  If  the  declaration  is  in  a  subroutine  and  the 
<allocatlon-speclf ler>  Is  omitted,  otherwise  It  Is  STATIC  (see  Section 
2.1.3).  Blocks  enclosed  In  blocks  Inherit  the  allocation  permanence  of 
the  enclosing  block. 

The  <block-decla ration)  describes  the  contents  of  the  block  either 
with  a  <block-type-narae>  (see  Section  2.2)  or  with  a  <block-body-part> . 
The  <block-body-part>  contains  explicit  declarations  of  all  the 
components  of  the  block. 

The  <block-preset> ,  If  present,  specifies  Initial  values  for  the 
block  components.  For  <block-declaratlons>  containing  a  <block-body- 
part)  rather  than  a  <block-type-name) ,  initial  values  may  be  specified 
with  <block-presets) ,  <table-presets)  and  <1 tem-presets)  on  the 
components  themselves. 

Const  ra int  s : 

Only  blocks  having  STATIC  allocation  (explicitly  or  by  default)  may 
contain  a  <block-proset)  or  a  <data-declaration)  containing  an  <ltem- 
preset),  <table-preset)  or  <block-preset) . 

If  a  <constant-declaratlon)  Is  In  a  block,  the  block  must  have 
STATIC  allocation  (explicitly  or  by  default). 

<Data-declaraClons)  within  a  block  must  not  contain  an  <allocatlon- 
speclf ler). 

Blocks  that  are  <formal-lnput-parameters)  or  <f ormal-output- 
parameters)  (see  Section  3.3)  must  not  contain  an  <allocation- 
speclfler),  a  <block-preset)  or  a  <data-declaratlon)  with  an 
<1 tem-preset) ,  <table-preset)  ,  or  <block-preset) . 

Components  of  blocks  declared  with  a  <block-type-name)  may  be 
accessed  only  by  using  pointers  to  the  blocks. 

2.1.5  ALLOCATION  OF  DATA  OBJECTS 
Syntax; 

<aIlocatlon-speclf ler)  ;:=  STATIC 

Semantics; 

Allocation  of  storage  for  a  data  object  can  be  STATIC  or  automatic. 
STATIC  allocation  means  that  the  data  object  Is  to  exist  throughout  the 

35 


89 


HIL-STD-1589B  (USAF) 
06  June  1980 


entire  execution  of  the  program.  Automatic  allocation  la  applicable 
only  to  data  declared  within  subroutines  and  means  that  the  data  object 
need  only  exist  while  the  subroutine  Is  executing  (l.e.,  values  are  not 
necessarily  preserved  between  calls).  Automatic  Is  the  default 
allocation  for  data  declared  In  subroutines  and  cannot  be  explicitly 
specified.  STATIC  Is  the  default  for  data  not  declared  In  subroutines 
and  can  be  explicitly  specified  bath  Inside  and  outside  of  subroutines. 

The  treatment  of  STATIC  data  In  a  concurrent  processing  environment 
Is  Implementation-dependent  with  respect  to  which  data,  If  any,  are 
shared  among  processes. 

2.1.6  INITIALIZATION  OF  DATA  OBJECTS 
Syntax: 

<ltem-preset>  ::=  =•  <ltem-preset-value> 

<ltem-preset-value>  :  <corapile-t lme-formula>  (5.0) 

I  <loc-functlon>  (6.3.1) 

<table-preset>  :  ■  <table-preset-llst> 

<table-preset-llst>  <default-preset-subllst> 

I  (<default-preset-sublist>  ,] 

<speclf led-preset-subllst> , . . . 

<default-preset-subllst>  ::=■  <preset-values-option> , . . . 

<speclf led-preset- 

subllst>  ::=■  <preset-lndex-speclf  ler> 

<preset-values-opt lon> , . . . 

<preset-I ndex-specl f  ler>  ;  ;=•  POS  (  <cons  tant-index> , . . .  )  s 

<constant-lndex>  <complle-tlme-lnteger-formula>  (5.1.1) 

I  <complle-tlme-status-formula>  (5.4) 

<preset-values-optlon>  : (<1 tem-preset-value>] 

I  <repetltlon-count> 

(  <preset-values-optlon> , . . .  ) 

<repetItlon-count>  :  <coroplle-tlme-lnteger-forroula>  (5.1.1) 
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<block-preset> 

<block-preset-llst>  ::= 

<bl  ock-preset-valuos-  ;:  = 

opt lon> 

I 

I 


-  <block-preset-l lst> 
<block-preset-values-opt lon> , . ■ . 
<prfset-va]ues-optlon> 

((  <table-preset-l 1 st>  )] 

[(  <block-preset-l 1 st>  )] 


Semantics ; 

Items,  tables,  and  blocks  with  STATIC  allocation  can  be  given 
Initial  values  by  means  of  <1 t em-preset s> ,  <table-presets> ,  and 
<block-presets> ,  respectively.  Furthermore,  constant  Items  and  tables 
must  be  given  initial  values  with  <1 tem-preset s>  and  <table-presets> . 
Initial  values  are  values  of  the  variables  after  a  module  has  been 
loaded  but  prior  to  any  dynamic  reference  to  the  variables.  They  do  not 
Imply  any  provision  for  later  restoring  values  to  the  Initial  state. 


An  <1 tcm-prcset>  specifies  an  Initial  value  for  an  Item. 

A  <t*bl«-pres*t>  specifies  m  list  of  Initial  values.  If  the 
<table-preset>  occurs  on  an  Item  within  an  entry  of  a  table,  the 
<table-pres«t>  specifics  values  only  for  that  ite».  If  the  table  Is 
dimensioned,  the  <table-pr«seC>  for  the  item,  if  present,  may  specify  a 
list  of  values  to  Initialize  that  Item  In  each  entry  of  the  dimensioned 
table . 


If  the  <table-preset>  occurs  on  an  entry  of  a  table,  the 
<table-preset>  specifies  values  for  all  items  within  that  entry.  If  the 
table  is  dimensioned,  the  <table-preset>  specifies  values  for  all  the 
items  in  each  entry  of  the  dimensioned  table.  Assuming  the  entry  has  N 
Items  In  It,  the  first  N  values  In  the  <table -preset>  are  Initial  values 
for  the  N  Items  In  the  first  entry  of  the  table  (in  the  order  In  which 
the  declarations  appear),  the  second  N  values  In  the  <table-preset>  are 
Initial  values  for  the  N  Items  in  the  second  entry  of  the  table,  etc. 

Entries  within  a  dimensioned  table  are  normally  Initialized  in 
order,  the  first  entry  being  the  one  with  the  lowest  value  of  each 
dimension  index,  and  proceeding  with  the  rightmost  indices  Increasing 
most  rapidly.  This  Is  the  procedure  followed  when  a  <default-preset- 
sublist>  Is  specified.  If  a  <specif led-preset-subllst>  Is  used, 
initialization  using  the  values  in  the  subllst  will  start  with  the  entry 
whose  Indices  are  specified  In  the  <preset'-lndex-specif ier>  and  will 
proceed  with  the  rightmost  Indices  Increasing  most  rapidly. 

A  <repetltlon-count>  can  be  used  as  a  shorthand  to  specify  the 
number  of  consecutive  repetitions  of  the  sequence  of  <preset-values- 
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optlons>  enclosed  In  the  parentheses  following  the  <repetltlon-count> . 

If  a  value  Is  omitted  In  the  <table-preset> ,  the  Item  corresponding 
to  the  omitted  value  will  remain  uninitialized  and  cannot  be  given  an 
Initial  value  elsewhere  In  the  preset. 

A  <block-preset>  Is  used  only  to  Initialize  a  block  declared  with  a 
<block-type-name> .  The  <block-preset-llst>  specifies  initial  values  for 
the  Items,  tables  and  blocks  contained  within  the  block  In  the  order  of 
their  declaration.  A  parenthesized  <table-preset-ll6t>  Is  used  to 
Initialize  a  contained  table  and  a  parenthesized  <block-pre!;et-llst>  Is 
used  to  Initialize  a  contained  block.  An  omitted  entry  from  the  list 
Indicates  that  the  corresponding  Item,  table,  or  block  will  remain 
unlnl  t  la  11  zed  . 

Constraints : 


The  type  of  each  value  In  an  <i tem-preset> ,  <table-preset>  or 
<block-preset>  must  match  or  be  Implicitly  convertible  to  the  type  of 
the  data  object  being  initialized  (see  Section  7.0), 

The  <preset-lndex-specif lers>  within  a  <t able-preset>  must  be 
specified  such  that  no  bit  position  is  Initialized  more  than  once  and 
the  bounds  of  the  table  are  not  exceeded. 

The  value  of  the  <repetitlon-count>  must  not  be  negative. 

An  item  must  not  be  initialized  more  than  once  by  Initializing 
another  Item  that  overlaps  it. 

The  type  of  each  <constant-index>  In  a  <pre&‘?t-Index-specifler> 
must  match  the  type  of  the  bounds  of  the  corresponding  dimension  In  the 
<diraension-llst>  of  the  declaration  of  the  table. 

The  number  of  <cor.stant-Indlces>  in  a  <preset-index-speclf ler>  must 
be  the  same  as  the  number  of  <diraenslons>  in  the  table's 
<dlmenslon-ll st> . 

If  the  argument  of  a  <loc-functlon>  used  as  a  preset  value  is  a 
<naraed-varlable> ,  it  must  be  a  <data-name>  for  an  object  whose 
allocation  permanence  is  STATIC,  either  explicitly  or  by  default. 
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2.2  TYPE  DECLARATIONS 


Syntax! 


<type-declaratlon> 

1 

1 

<1 tem-ty pe-decla rati on> 

<table-type-declara tlon> 

<block-type-declarat lon> 

<1  tern- type-dec la rat lon> 

= 

TYPE  <i tem-type-name> 
<ltem-type-descrlptlon>  : 

(2.1.1) 

<1 tem-type-name> 

:  :  = 

<name> 

(8.2.1) 

<t able- type-dec la ra t lon> 

:  :  = 

TYPE  <table-type-name> 

TABLE  <table-type-specifler> 

<t able- type-sped  f  ier> 

1 <dlmenslon-l i st> ] 
{<structure-speclf ler>] 
I<llke-option>l 
<entry-specif ier> 

(2.1 .2.1) 
(2.1  .2.2) 

(2.1.2) 

1 

(<dlmension-llst>l 
<table-type-name>  ; 

(2.1 .2.1) 

<table-type-name> 

<name> 

(8.2.1) 

<llke-optlon> 

:  :  = 

LIKE  <table-type-name> 

<block-type-declarat lon> 

:  :  = 

TYPE  <block-type-name> 

BLOCK  <block-body-part> 

(2.1.4) 

<block-type-narae> 

:  :  = 

<name> 

(8.2.1) 

Semantics : 

A  <type-declaratlon>  Is  used  to  give  a  name  to  a  type 
specification. 

An  < i t em-t ype-dec la ra t ion>  associates  the  <ltcD-type-nanie>  with  the 
<i tem-ty pc-de script  I on> . 

A  <table-Lype-dec laration>  associates  the  <table-type-name>  with 
the  <table-type-speclf ler> . 

If  a  <1 lke-option>  Is  specified,  the  entry  being  described  consists 
of  the  items  in  the  tyj.e  named  in  the  <1 ike-option>  together  with  the 
Items  in  the  <ent ry-spec t f i er> .  Tlic  physical  positioning  of  items  in 
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the  <llke-optlon>  relative  to  the  start  of  the  entry  Is  fixed  at  the 
time  the  <llke-optlon>  type  name  Is  declared  and  Is  not  changed  by  Its 
use  as  a  <llke-optlon>.  If  the  type  named  In  the  <llke-optlon>  contains 
a  <dlmenslon-speclf ler>.  It  applies  to  the  entire  <tahle-type- 
speclfler>.  If  the  table  Is  an  ordinary  table,  the  <packlng-speclf ler> , 
If  present,  only  applies  to  the  Items  In  the  <entry-6peclf ler> ,  not  to 
the  Items  obtained  from  the  <llke-optlon>.  If  the  table  Is  a  specified 
table,  the  <words-per-entry>  In  the  <entry-speclf ler> ,  If  present, 
specifies  the  total  size  of  the  entry  Including  the  Items  obtained  from 
the  <llke-optlon> .  If  the  <table-type-declaratlon>  contains  a 
<structure-speclf ler>  of  T,  <blts-per-entry>  specifies  the  total  number 
of  bits  the  entry  Is  to  occupy  Including  Items  obtained  from  the 
<llke-optlon> .  If  <bl ts-per-entry>  Is  omitted  It  will  default  to  the 
minimum  number  of  bits  needed  to  store  the  entry.  Including  Items 
obtained  from  the  <llke-optlon>. 

The  physical  representation  of  a  table  type  Is  fixed  by  the  type 
declaration.  All  objects  allocated  with  such  a  type  name  will  have  the 
same  representation.  In  particular,  the  position  of  table  Items  In  a 
<llke-optlon>  Is  not  modified  by  the  occurrence  of  a  <packing-speci f ler> 
or  <order-dlrective>  In  the  <entry-speclf ler> .  However,  unused  space  In 
the  portion  described  by  the  <llke-option>  can  be  occupied  by  table 
items  given  In  a  packed  <entry-speclfler>. 

A  <block-type-declaratlon>  associates  the  <block-type-name>  with 
the  <block-body-part>. 

For  type  matching  purposes,  a  type  name  Is  considered  to  be  an 
abbreviation  for  its  associated  <ltem-type-descr Ipt ion> , 
<table-type-specif ier>,  or  <block-body-part> ,  In  any  context  except 
within  a  <polnter-ltem-descrlption>. 

Constraints ; 

The  <ltem-type-descrlptlon>,  <table-type-speclf ler> ,  or  <block- 
body-part>  In  a  <type-declaration>  must  not  contain  an  <1 tem-preset> , 
<table-preset>  ,  or  <block-preset> . 

A  <block-body-part>  In  a  <block-type-declaratlon>  cannot  contain 
<constant-declara t Ions>. 

If  a  <table-type-specif ler>  contains  a  <dImenslon-l lst> ,  then  It 
must  not  contain  a  <table-type-name>  (either  directly  or  In  a  <ltke- 
optIon>)  whose  <table-type-declaratlon>  contains  a  <dlmensIon-list>. 

Tables  may  be  characterized  as  parallel,  serial,  tight,  ordinary, 
variable-length-entry,  and  specified.  The  characterizations  of  the 
table  type  In  a  <like-optlon>  must  be  the  same  as  those  of  the 
<table-type-declaratlon>  In  which  the  <llke-optlon>  appears. 
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<Words-per-ent ry>  of  the  <table-type-speclf ler>  must  net  specify  a 
value  that  Is  less  than  <words-per-ent ry>  of  the  type  name  specified  In 
a  <llk.e-optlon>. 

The  (explicit  or  default)  number  of  bits  per  entry  In  a 
<table-type-speclf ler>  having  tight  structure  must  not  be  less  than  the 
number  of  bits  per  entry  of  the  typo  name  specified  In  a  <llke-optlon>. 

A  <table-ty pe-name>  must  be  a  <name>  declared  In  a 

<table-type-declaratlon>. 

A  <block-type-narae>  must  be  a  <name>  declared  In  a 
<block.-type-declarat  lon> . 

Note : 


A  <table-type-name> ,  <ltem-type-name> ,  or  <bl ock- ty pe-name>  must 
not  be  a  formal  parameter  name  or  an  actual  parameter  name. 


2.3  STATEMENT  NAME  DECLARATIONS 
Syntax; 

<statement-narae-decla rat lon>  ;:=  LABEL 

<statement-name> , . . .  ;  (4.0) 


Semantics ; 

A  <statement-name-declaratlon>  Is  used  to  explicitly  declare  a 
<statement-name> .  Ordinarily,  a  <statoment-name>  Is  implicitly  declared 
by  Its  use  In  a  <label>.  An  explicit  <statement-naue-declaration>, 
however,  must  be  used  for  statement  name  <forraal-input-parameters> ,  for 
statement  names  that  are  the  same  as  <def ine-naraes>  declared  In  an 
enclosing  scope,  and  for  external  <statement-name-declarations> . 

Constraints : 


The  <stateraent-names>  in  a  <st3tement-name-declaratlon>  must  either 
be  <formal-input-parameters>  to  the  subroutine  containing  the 
<statemont-name-declaration>  or  else  must  be  used  in  <labels>  In  the 
Immediate  scope  containing  the  <stateraent-narae-dec la  rat ion>  (i.e.,  not 
Including  nested  scopes). 
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2.4  DEFINE  DECLARATIONS 


Syntax; 


<def ine-declaratlon> 

<def i ne-name> 

<def lnltlon-part> 

<formal-def I ne- para mete r- 
-llst> 

<forraal-  def  lne-paranieter> 
<def lne-strlng> 


DEFINE  <def lne-name> 

<def 1  nit Ion-par t> 

<name>  (8.2.1) 

[  <fortnal-def  lne-parameter-li6t>] 

<def ine-strlng>  ; 

(  <fortnal-def  lne-paranieter>  , .  . .  ) 

<letter>  (8.1) 

"  [<character> . . . ]  "  (8.1) 


Semant 1 c  s  : 

A  <deflne-declaratlon>  Is  used  to  associate  a  name  with  a  (possibly 
parameterized)  text  string,  the  <define-string>.  The  <def lne-string> 
will  be  substituted  for  the  <def lne-name>  when  the  <def lne-name>  Is  used 
in  a  <def lne-call>  (see  Section  2.4.1). 


The  <fornial-def  ine-parameter— llst>  is  used  to  declare 
<formal-def lne-parameters> .  These  parameters  receive  values  from 
<actual-def lne-parameters>  In  each  <def lne-call>  (see  Section  2.4.1). 
The  values  are  substituted  in  the  <def lne-string>  wherever  the 
<f ormal-def lne-parameters>  are  referenced.  Reference  to  a 
<f ormal-def lne-parameter>  within  the  <def lne-string>  is  indicated  by 
preceding  the  parameter  name  with  an  exclamation  point.  Such  parameter 
references  can  occur  anywhere  within  the  <def ine-strlng>  and,  by 
appropriate  juxtaposition,  can  be  used  to  create  new  symbols. 

Within  the  <def lne-string>,  the  quotation  mark  (")  and  exclamation 
point  (!)  can  be  used  as  simple  characters  by  doubling  them.  A 
<def lne-string>  Is  terminated  by  the  first  undoubled  quotation  mark, 
regardless  of  the  lexical  context  in  which  the  undoubled  quotation  mark 
appears . 

As  with  other  <names>,  a  <def lne-name>  Is  known  in  the  scope 
containing  its  declaration  and  may  be  redeclared  in  an  inner  scope. 

The  <def lne-etrlng>  may  contain  <def lne-calls>.  Such  calls  will  be 
expanded  for  each  substitution  of  the  <def Ine-str lng> ,  using  the 
definition  active  In  the  scope  of  the  <def lne-call> . 
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Constraints : 

A  <coD)nient>  delimited  by  quotation  marks  must  not  occur  In  a 
<def lne-declaratlon>  between  the  <def lne-nams>  and  the  <def lne-strlng>  . 

Circular  <def lne-dec]aratlons>  as  the  result  of  <def lne-strings> 
containing  <def lne-calls>  are  not  allowed. 

The  same  <letter>  must  not  appear  more  than  once  In  any 
<formal-def Ine-pa rameter-1 lst>. 

2.A.1  DEFINE  CALLS 

Syntax! 

<def lne-call>  . 

<actual-def Ine-parameter- 
llst> 

<actual-def lne-parameter>  : (  <character> , . ,  ]  (8.1) 

I  "  (<character> . . . ]  "  (8.1) 

Semantics ! 

A  <def ine-cal 1>  is  used  to  cause  textual  substitution  to  occur.  A 
<def ine-ca 11>  is  processed  as  follows: 

1.  The  characters  comprising  <actual-def ine-parameters>  are 

substituted  for  the  corresponding  <fonnal-def ine-parameters> 
in  the  <def ine-string>  associated  with  the  <def lne-name> . 

2.  The  resulting  <def lne-strlng>  logically  replaces  the 

<def lne-call> . 

3.  The  substituted  <def lne-strlng>  Is  scanned  from  Its  beginning 
to  determine  what  <symbols>  it  contains;  these  <symbols>  are 
processed  as  though  they  had  appeared  in  the  orglnal  text  at 
the  point  of  the  replaced  <def ine-cal 1>. 

Note  that  the  substituted  source  text  may  be  found  to  contain 
<def lne-calls>  and  these  are  processed  In  the  same  manner. 

If  an  <actual-def lne-parameter>  Is  omitted,  a  null  string  will  be 
substituted  for  the  <formal-dcf Ine-parameter>.  If  the  number  of 
<formal-deflne-pararaeters>  exceeds  the  number  of 

<actual-def lne-parameters> ,  null  strings  will  be  substituted  for  the 


=  <def 1 ne-name>  (2.4) 

[<actual-def Ine-pa rameter-1 lst>] 

=  (  <actual-deflne-parameter>,  . .  .  ) 
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trailing  <f ormal-def Ine-paramc ters> . 


If  a 

n  <actual-def ine-parameter>  consl 

sts 

of  ch 

arac 

ter 

s 

enclosed  in 

quotation 

marks 

,  all  the  enclosed  eba 

rac  t 

ers 

are 

sub 

iSt 

1 1  u  t  ed  . 

The 

quotation 

ma  rk  ( 

")  must  be  doubled  within 

an  a 

ct  ual 

pa 

ramet 

er  enc 

losed 

in  quotes 

• 

If 

an  < 

actual-definc-paraineter> 

doe 

s  not  c 

ont 

a  i 

n  end 

oslng 

quotation 

ma  rks , 

the  characters  substltut 

ed 

are 

the 

fl 

rs 

t  non- 

blank 

character 

and  su 

bsequent  characters  ending 

at , 

bat 

not 

1  nc 

lu 

ding,  c 

1  ther 

(1)  the 

f  irst 

right  parenthesis  that 

1  s 

not 

bal 

anc 

ed 

by  a 

left 

parenthes: 

is  that 

Is  part  of  the  <actual-do 

f  1  ne 

-para 

mete 

r>. 

or  (2) 

the 

first  comma  that  Is  not  between  such  balanced  parentheses. 

<Def Ine-cal ls>  are  not  recognized  In  <cominents>  and  <character- 
llterals> . 

Constraints ; 

The  <actual-def lne-parameter-llst>  must  not  be  omitted  If  the 
corresponding  <def ine-declaratlon>  contains  a  <formal-def 1 nc-paiaiueter- 
llst>. 

The  number  of  <actual-def ine-parameters>  must  not  be  greater  than 
the  corresponding  number  of  <f ormal-def ine-parame t ers> . 

A  <def i ne-cal 1>  cannot  be  juxtaposed  with  surrounding  symbols  so  as 
to  create  new  symbols  after  substitution. 

A  <def ine-call>  must  not  be  used  as  the  <name>  being  declared 
within  a  declaration. 

A  <def ine-ca 1 1>  must  not  be  used  as  a  <formal-lnput-parameter>  or 
<f ormal-output-parameter>  within  a  <piocedure-hcadi ng>  or  <functlon' 
heading> . 

The  same  <letter>  must  not  appear  more  than  once  In  any 
<formal-def Ine-parame ter-1 is t>. 

Note : 

The  def lne-11 sting  directives  (see  Section  9.7.2)  allow  programmer 
control  over  whether  the  source  program  listing  contains  the  expanded 
string,  the  define  Invocation,  or  both,  for  <def Ine-cal 1 s> . 

Examples ; 

DEFINE  FOO(A)  "BAZ  !AFAZ  lA"; 

DEFINE  BAR  "HELLO"; 
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DEFINE  BARFAZ  "GOODBYE"; 

DEFINE  HELLOFAZ  "NOT  USED"; 

FOO(BAR) 

The  result  of  the  <def lne-call>,  FOO(BAR),  after  substituting  for  the 
formal  parameter  lA  Is  BAZ  BARFAZ  BAR,  and  after  rescanning  this  string, 
the  final  result  Is  BAZ  GOODBYE  HELLO. 

DEFINE  MAKEDEF(N,  S)  "DEFINE  IN  "•’is"""; 

MAKEDEF(NEW,  HELLO); 


The  result  Is  DEFINE  NEW  "HELLO";  ,  l.e.,  a  new  <de f 1 ne-decl a ra t 1 on> . 


2.5  EXTERNAL  DECLARATIONS 
Sj'  t^ax : 


<ext ernal-dec la ra 1 1 on>  :  :=  <def-specl f icat lon>  (2.5.1) 

1  <ref-specl f 1  cat lon>  (2.5.2) 

S^mant 1 cs ; 

<External-declaratlons>  declare  <names>  that  are  potentially  known 
in  other  <modules>  of  the  <complete-program> .  Such  names  are  said  to  be 
external . 

Const  ral nt : 

Formal  parameter  names  cannot  be  declared  external. 


2.5.1  DEF  SPECIFICATIONS 
Syntax : 

<def-specif icat ion>  :  :  = 

I 

<slmple-def>  : 

<compound-def>  :  :  = 


<slmple-def> 

<compound-de  f > 

DEF 

<def-speclf lcatlon-cholce> 

DEF  BEGIN 

<def-specl f 1 cat lon-cholce>  .  . . 
END 
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<def-speclf lcatlon-cholce>  ; <null-declarat lon> 


(2.7) 


I  <data-decl8ratlon>  (2.1) 

I  <def-block-lnstantlatlon> 


<def -block- Ins  tan t la tlon> 

Semantics ; 


I  <statement-nanie-declaratlon>  (2.3) 

I  <dlrectlve>  (9.0) 

<def -sped  flea tlon-cholce> 

::=  BLOCK  INSTANCE 

<block-name>  ;  (2.1.4) 


<Def-speclf lcatlons>  enable  data  objects  to  be  declared  that  are 
potentially  available  via  <ref-specl f icat lons>  and/or  <compool- 
dlrectlves>  for  use  In  other  <modules>.  Physical  storage  will  be 
allocated  for  these  objects. 


Either  a  <def-block-lnstantlatlon>  or  a  <block-declaratlon>  may  be 
used  In  a  <def-speclf lcatlon>  to  create  a  block  with  external  scope. 
However,  In  order  for  a  <def-block-lnstant lat lon>  to  be  meaningful,  a 
<ref-speclf lcation>  containing  a  <block-declaration>  having  the  same 
<block-name>  must  exist,  either  In  that  <module>  or  In  a 
<conipool-module>  that  Is  referenced  via  a  <compool-dlrectlve>.  Preset 
Information  used  In  the  creation  of  a  block  declared  with  a 
<def-block-lnstantiatlon>  will  be  obtained  from  the  corresponding 
<ref-speci f Icat ion> . 

A  <statement-name-declaratlon>  In  a  <def-speclf ication>  makes  the 
addresses  of  the  designated  statements  available  as  linkage  Information 
In  the  environment  of  the  <complete-program>  but  does  not  make  these 
names  available  as  targets  of  out-of-scope  GOTO  statements  (see  Section 
4.7). 


Constraints ; 

A  data  declaration  In  a  <def-speclf lcatlon>  and  a  corresponding 
declaration  In  a  <ref-speclf icatlon>  must  agree  In  name,  type,  and  all 
attributes.  However,  a  compiler  will  perform  this  check  across  <module> 
boundaries  only  If  a  connection  Is  established  between  the  <modules>  via 
a  <compool-directlve>. 

External  data  must  have  STATIC  allocation,  either  explicitly  or 
implicitly. 
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The  <data-declaratlon>  In  a  <def-speclf lcatlon>  cannot  be  a 
<cons t ant-decla ra t lon> .  (This  constraint  does  not  prevent  ^constant— 
declaratlons>  from  appearing  In  <block-declaratlons>  In  <def- 
speclf lcatlons>.) 


2.5.2  REF  SPECIFICATIONS 
Syntax: 

<ref-speclf lcatlon>  ; 

I 

<simple-ref>  ::= 

<compound-re£>  :  :  = 

<ref-specl f lcatlon-cholce> 

I 

I 

I 

I 


<slmple-ref> 

<compound-ref> 

REF 

<ref-speclf Icat lon-cholce> 
REF  BEGIN 

<ref-speclflcatlon-cholce>. . . 


END 

<nuIl-declaratlon>  (2.7) 
<data-declaratlon>  (2.1) 
<subroutlne-declaratIon>  (3.0) 
<dlrectlve>  (9.0) 


<ref-specl f lcatlon-cholce> 
<statement-naine-declaratlon>  (2.3) 


Semantics ; 

A  <ref-speclf lcatlon>  enables  a  <module>  to  reference  a  <name> 
whose  <def-si>eclf icatlon>  is  In  another  <mndule>. 

Physical  storage  for  external  names  occurs  In  the  <module> 
containing  the  <def-speclf lcatlon>  and  not  In  the  <niodule>  containing 
the  <ref-speclflcatlon>. 

A  <ref-speclf lcatlon>  for  a  <name>  may  appear  in  a  <compool-fflodule> 
and  the  corresponding  DEF  In  another  <module>.  In  that  case,  the  <name> 
will  be  available  for  use  In  any  other  module  of  the  <c omplet e-prog rain> , 
provided  that  the  referencing  module  has  the  appropriate 
<compool-dlrectlve>.  The  compiler  will  enforce  the  requirement  that  the 
DEF  and  the  REF  specifications  agree,  provided  the  <module>  containing 
the  DEF  has  the  appropriate  <compool-dl rectlve>.  Alternatively,  the 
<ref-speclf lcatlon>  may  appear  In  the  accessing  <module>  directly 
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Instead  of  In  a  conpool  (bypassing  ihe  compool  entirely),  but  In  this 
case  it  will  be  beyond  the  compiler's  ability  to  check  for  compatibility 
between  the  DEF  and  the  REF  specifications.  When  <ref-speclf icatlons> 
are  used  outside  of  compools  to  gain  access  to  external  names,  the 
programmer  Is  entirely  responsible  for  the  correct  usage  of  those  names. 

For  <data-declaratlons>  In  a  <def-speclf lcatlon>  that  Is  In  a 
<compool-module> ,  no  <ref-speciflcatlon>  Is  necessary  If  the  accessing 
module  has  a  <compool-dlrect lve>  that  causes  that  data  to  be  Imported 
(see  Section  9.1). 

Constraints : 


For  every  <data-declaratlon>  In  a  <ref-specl f lcatlon> ,  there  must 
exist  a  corresponding  declaration  In  a  <def-speclflcatlon>.  For  every 
<'subroutlne-declaratlon>  In  a  <ref-specl f icat lon> ,  there  must  exist  In 
some  <procedure-module>  or  <Bialn-program-modul e>  a  corresponding 
<procedure-def lnltlon>  preceded  by  DEF. 

In  a  <ref-specl f lcatlon> ,  presets  are  Illegal  In 
<ltem-declarations>  and  <table-declarations>  and  are  optional  in 
<block-declaratlons> .  A  <ref-speclf ication>  that  contains  presets  can 
be  used  only  In  conjunction  with  a  <def-block-lnstantiatlon>. 

A  <data-declaration>  in  a  <ref-spocl f icat ion>  cannot  be  a 
<constant-declarat ion> .  (This  constraint  does  not  prevent 
<constant-declaratlons>  from  appearing  in  <block-declaratlons>  in 
<ref-specl f lcatlons>). 


2.6  OVERLAY  DECLARATIONS 
Syntax ; 

<over lay-dec la ration> 

<absolute-address> 

<over lay-add ress> 
<overlay-expresslon> 
<overlay-strlng> 
<overlay-element> 


OVERLAY 

(<absolut e-add ress>] 

<overlay-expression>  ; 

POS  (  <overlay-address>  )  : 

<complli-tIme-integer-f ormula>  (5.1  .1) 

<overlay-strIng> : . . . 

<overlay-element> , . . . 

<spacer> 
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<spacer> 

<data-name> 


Semantics: 


I  <data-naiiie> 

I  (  <overlay-expresslon>  ) 

=  W  <coinplle-tlme-lnteger-fonnula>  (5.1  •!) 

=  <ltein-nanie>  (2.1.1) 

I  <table-nanie>  (2.1.2) 

I  <block-name>  (2.1.4) 


An  <overlay-declaratlon>  Is  used  to  specify  any  or  all  of  the 
following: 

1)  that  data  objects  are  to  have  a  specl^'tc  allocation  order 

2)  that  certain  data  objects  are  to  occupy  the  same  memory 
locations  as  other  data  objects 

3)  that  certain  data  objects  are  to  be  allocated  at  a  particular 
absolute  memory  location 

The  <overlay-elements>  in  an  <overlay-string>  are  allocated  memory 
locations  in  the  order  of  their  appearance  In  the  string.  The  memory 
locations  allocated  to  the  elements  of  an  <overlay-strlng>  that  appears 
to  the  left  of  a  colon  In  an  <overlay-expresslon>  are  overlayed  with  the 
space  allocated  to  the  elements  of  the  <overlay-string>  that  appears  to 
the  right  of  the  colon. 

The  <overlay-address>  specifies  an  absolute  mempry  location  at 
which  allocation  of  the  <overlay-expression>  begins.  The  meaning  of  an 
overlay  address  Is  machine  dependent. 

A  <spacer>  In  an  <overlay-string>  specifies  a  number  of  words  to  be 
skipped  during  allocation. 

Constraints : 


The  allocation  permanence  of  all  data  objects  in  an 
<overlay-declaration>  must  be  the  same  (i.e.,  all  STATIC  or  all 
automatic) . 

An  <overlay-declaratlon>  within  a  <block-declaratlon>  or 
<block-type-declaratlon>  must  not  reference  data  names  declared  outside 
the  block  or  block  type  or  within  nested  blocks. 
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An  <overlay-declaratlon>  outside  a  <block-declaratlon>  or 

<block-type-declaratlon>  must  not  reference  data  names  declared  within  a 
block  or  block  type. 

An  <overlay-declaratlon>  within  a  <block-declarat lon>  or 

<block— ty pe— dec 1 a ra t lon^  must  not  Include  an  ^absolute— address^. 

A  <block-declaratlon>  or  <b]ock-type-declaratlon>  must  not  include 
an  <overlay-declaratlon>  If  an  <order-dlrectlve>  Is  In  effect  for  the 
block  or  block  type. 

Declarations  for  all  <data-names>  In  an  <overlay-declaratlon>  must 
precede  the  <overlay-declaratlon>,  and  all  must  be  In  the  same  scope. 

<0ve rlay-decla ra t lons>  cannot  be  used  to  specify  more  than  one 
physical  location  to  any  data  object. 

Names  of  formal  parameters  cannot  be  used  In 

<over lay-dec  la ratlons> . 

If  an  <overlay-address>  Is  specified,  all  <data-names>  used  In  the 
<overlay-expresslon>  must  have  an  (explicit  or  default)  allocation 
permanence  of  STATIC. 

Note : 


A  <data-name>  In  an  <overlay-declaratlon>  cannot  be  declared  In  a 
<const ant-dec la ration>. 


2.7  NULL  DECLARATIONS 
Syntax; 

<null-declaratlon>  ; ; 

I  BEGIN  END 


Semantics : 


A  <null-declaration>  has  no  semantic  effect. 
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3.0  PROCEDURES  AND  FUNCTIONS 

Syntax: 

<subroutine-declaratlon> 

:  :=  <procedure-declaration> 

(3.1) 

1  <funct ion-declarat lon> 

(3.2) 

<subroutlne-def ini tlon> 

:  :=  <proC'?dure-def  1  ni  t  i  on> 

(3.1) 

1  <f unct lon-def i nl t 1 on> 

(3.2) 

1  <dlrectlve> 

<subroutlne-deflnition> 

(9.0) 

Semantics ; 

Subroutines  describe  algorithms  that  may  be  executed  from  more  than 
one  place  In  a  <coraplete-program>.  A  subroutine  Is  either  a  procedure, 
which  Is  Invoked  by  a  <procedure-call-statement> ,  or  a  funrtioji,  wliich 
Is  Invoked  by  a  <f unct lon-call>, 

A  <subroutlne-def lnltlon>  contains  the  executable  code  for  the 
subroutine,  In  addition  to  declarations  for  all  local  data  and  formal 
parameters,  as  well  as  definitions  of  any  nested  subroutines.  A 
<subroutine-def ini tlon>  Is  said  to  define  the  subroutine. 

A  <subroutlne-declaratlon>,  on  the  other  hand.  Is  said  to  declare 
the  subroutine.  A  <subroutine-declaratlon>  contains  the  heading  of  the 
subroutine  and  <declaratlons>  for  the  formal  ptrameters,  but  it  contains 
no  executable  code.  A  <subroutine-declaration>  is  required  in  a 
<ref-specificatlon>  for  each  subroutine  that  is  invoked  in  a  module 
other  than  the  module  containing  Its  definition  (see  Section  2.5).  A 
<subroutlne-declaration>  Is  also  required  in  two  other  situations:  (1) 
when  a  subroutine  name  Is  declared  as  a  formal  parameter  (see  Section 
3.3),  and  (2)  when  the  name  of  the  subroutine  is  the  same  as  a 
<def lne-nanie>  In  an  enclosing  scope.  It  is  not  necessary  to  provide  a 
<subroutlnc-declaratlon>  If  the  subroutine  is  Invoked  only  In  the 
<module>  where  it  Is  defined  and  if  its  name  is  not  passed  as  a 
parameter  or  used  in  an  enclosing  scope  as  a  <define-name>. 

Constraints : 


The  <procedure-headlng>  or  <functlon-heading>  of  a  <subroutiiie- 
declaratlon>  and  that  of  the  corresponding  <subroutlne-deflnltlon>  must 
have  identical  attributes,  and  the  parameters  (both  input  and  output) 
must  agree  in  number,  type,  and  order.  (This  constraint  will  be 
enforced  only  when  the  declaration  is  known  in  the  scope  of  the 
definition.)  Also,  the  subroutine  name  in  the  declaration  and 
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definition  must  be  the  same  (unless  the  ^subroutine-declaration^  Is  for 
a  formal  parameter). 


3.1  PROCEDURES 
Syntax : 


<pr ocedur e-dec  la  rat lon> 

::=  <procedure-headlng>  ; 
<declaratlon> 

(2.0) 

<procedure-def Inl t lon> 

<procedure-headlng>  ; 
l<dlrectlve> .  . .] 

<procedur e-bod y> 

(9.0) 

<procedure-hoadlng> 

:  :=  PROC 

<procedure-name> 

[ <subrou t Ine-a  1 1  rl but e> ) 
[<formal-parameter-l  1  6t>l 

(3.3) 

<subroutlne-attribute> 

: :=  REC 

1  RENT 

<procedure-narae> 

: ;=  <naroe> 

(8.2. 

<procedure-body> 

:  <subroutlne-body> 

<subroutlne-body> 

::=  <statement> 

(4.0) 

1  BEGIN  [<declaratlon>. . .] 
<statement> . , . 

(<subroutine-def Inl tlon> . . . ] 
{<dlrectlve>. , . ] 

|<label>...]  END 

(2.0) 

(4.0) 

(3.0) 

(9.0) 

(4.0) 

Semant Ics ; 

The  <procedure-headlng>  In  a  <procedure-declaratlon>  may  contain  a 
<fon)nal-parameter-llst>,  which  specifies  the  names  that  are  used  In  the 
<procedure-body>  to  refer  to  the  corresponding  arguments  supplied  by 
each  call  of  the  procedure.  The  syntax,  semantics,  and  constraints  for 
a  procedure's  <fonnal-parameter-llst>  are  the  same  as  for  a  function's 
<forraal-parameter-llst>,  and  are  presented  In  Section  3.3. 

The  differences  between  a  <procedure-declaratlon>  and  a 
<procedure-deflnltlon>  are  described  In  Section  3.0. 


A  <subroutlne-attrlbute>  of  REC  Indicates  that  the  subroutine  Is 
potentially  recursive ,  l.e.,  that  at  run  time,  an  Invocation  of  the 
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subroutine  raay  be  dynamically  nested  within  another  Invocation  of  It. 
If  REC  Is  present,  physical  allocation  of  locally-declared  automatic 
data  will  occur  dynamically.  The  data  will  be  allocated  and  deallocated 
when  the  subroutine  Is  entered  and  exited,  respectively.  This  assures 
that  separate  copies  of  the  local  data  will  exist  for  each  successive 
call  In  the  recursive  chain.  Locally-declared  STATIC  data,  however, 
will  be  allocated  once,  and  the  same  storage  will  be  used  for  all  calls 
of  that  subroutine  throughout  the  <complet e-program> . 

A  <subroutlne-attrlbute>  of  RENT  Indicates  that  the  subroutine  Is 
re-entrant  and  may  therefore  be  executed  concurrently  In  a  concurrent 
processing  environment.  A  recursive  subroutine  Is  also  re-entrant. 

If  execution  of  the  <procedure-body>  Is  completed  without  executing 
a  RETURN  statement,  an  ABORT  statement,  or  a  GOTO  statement  whose  target 
Is  the  name  of  a  formal  parameter,  an  implicit  RETURN  statement  Is 
executed . 

Constraints: 

A  <procedure-declaratlon>  can  contain  no  <decla rat ions>  other  than 
those  for  the  procedure's  formal  parameters.  <Declaratlons>  of  local 
data  appear  only  in  the  procedure's  definition. 

A  procedure  must  not  be  invoked  recursively  If  It  Is  not  declared 

REC. 


A  procedure  must  not  be  Invoked  re-entrantly  if  it  is  not  declared 
RENT  or  REC. 

A  <subroutlne-body>  must  contain  at  least  one  non-null  <statement> 
(e.g.,  RETURN). 


3.2  FUNCTIONS 


Syntax; 


<funct lon-declarat ion> 

:  :=  <f unction-heading>  ; 

<declaratlon> 

(2.0) 

<f unct lon-def ini t lon> 

:  <function-heading>  ; 

[ <di rec 1 1 ve> . . .  ] 

<f unct lon-body> 

(9.0) 

<f unctlon-headlng> 

PROC  <functlon-name> 

[<subroutlne-attrlbute>] 

(3.1) 

(<forma 1-par ameter-list>l 

(3.3) 

<lteBi-type-descrlptlon> 

(2.1.1) 
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<functlon-nanc> 
<funct lon-body> 
Semantics : 


<name>  (8.2.1) 

<subro\it  1  ne-body>  (3.1) 


The  differences  between  a  <f unct Ion-dec larat lon>  and  a 
<f unctlon-dof 1 nl t i on>  are  described  In  Section  3.0. 

The  <lteni-typc-desrrlptlon>  specifies  the  type  of  the  return  value 
of  the  function.  Within  the  body  of  the  function,  the  name  of  the 
function  may  be  assigned  to  as  a  variable  In  an  <asslgnment-statenent> . 
When  the  function  is  exited,  the  most  recent  value  assigned  to  the 
< f unct ion-name>  Is  used  as  the  value  of  the  function.  The  return  value 
Is  considered  to  be  allocated  as  automatic  storage  (see  Section  2.1.5). 

Use  of  the  <function-name>  In  a  <formula>  within  the  body  of  the 
function  is  a  recursive  invocation  of  the  function.  Within  the  body  of 
the  function,  the  <f unctlon-name>  may  also  be  used  as  an 
<actual-lnput-pa rameter>  in  a  subroutine  call  when  the  corresponding 
<formal-input-parameter>  is  a  <f unct lon-name>  (see  Section  3.3). 

The  <functlon-headlng>  In  a  <function-declarat lon>  or  <functlon- 
dofinltion>  may  contain  a  <formal-parameter-llst> ,  which  specifies  the 
names  that  are  used  In  the  <functlon-body>  to  refer  to  the  corresponding 
arguments  supplied  by  each  call  of  the  function.  The  syntax,  semantics, 
and  constraints  for  a  function's  <formal-parameter-l ist>  are  the  same  as 
for  a  procedure's  <formal-parameter-llst> ,  and  are  presented  in  Section 
3.3. 


The  Inclusion  of  an  <item-type-description>  in  the  heading  of  a 
subroutine  indicates  that  the  subroutine  is  a  function. 

The  <subroutlne-attrlbutes>  of  REC  and  RENT  apply  to  functions  In 
the  same  way  as  for  procedures  (see  Section  3.1). 

If  execution  of  the  <functlon-body>  Is  completed  without  executing 
a  RETUPJ^  statement,  an  ABORT  statement,  or  a  GOTO  statement  whose  target 
is  the  name  of  a  formal  parameter,  an  implicit  RETURN  statement  is 
executed . 

Constraints : 


The  <f unct lon-name>  may 

<actual-output-parameter> . 


not  be 


used  as  an 


The  <funct ion-name>  Is 
function  body. 


not  declarable  as  a  <name>  within  the 
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A  <f unctlon-declaratlon>  can  contain  no  <declaratlons>  other  than 
those  for  the  functions  formal  parameters.  <Declaratlons>  of  local  data 
appear  only  In  the  function's  definition. 

A  function  must  not  be  invoked  •  utslvely  If  it  Is  not  declared 

REC. 

A  function  must  not  be  Invoked  re-entrantly  If  It  Is  not  declared 
RENT  or  REC. 

The  <functlon-name>  must  be  assigned  a  value  before  the  function  Is 
exited. 


3.3  PARAMETERS  OF  PROCEDURES  AND  FUNCTIONS 
Syntax; 


<forraal-parameter-llst>  : := 

(  (<formal-lnput-pa rameter> , . . . ] 

(  ;  <formal-output-parameter>, . . 

.  ]  ) 

<formal-lnput-parameter>  ; := 

I<parameter-bi ndlng>) 
<lnput-paramet er-name> 

<f orma 1-out  put- pa rameter> : :  = 

( <parame ter-blndl ng>  J 
<output-parameter-name> 

<parameter-bindlng>  ; 

BYVAL 

1 

BYREF 

1 

BYRES 

<input-parameter-name>  : 

<data-name> 

(2.6) 

1 

<statement-name> 

(A.O) 

1 

<subroutlne-name> 

<output-parameter-narae>  ;;= 

<data-name> 

(2.6) 

<subrout lne-name>  ; := 

<procedure-name> 

1 

<functlon-name> 

(3.2) 

Semantics; 

Parameters  permit  subroutines  to  have  locally-declared  <names>  that 
correspond  to  entitles  whose  values  can  be  different  for  different 
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calls. 


<ForDial-lnput-parameter6>  and  <foniial-output-paranieters>  constitute 
the  formal  parameters  of  the  subroutine.  When  the  subroutine  Is 
Invoked,  the  formal  parameters  are  associated  with  a  corresponding  list 
of  actual  parameters  supplied  In  the  subroutine  call  (see  Section  4.5). 

<Formal-lnput-parameters>  transfer  values  Into  the 

<subroutlne-body>  from  the  corresponding  <actual-lnput-parameters> . 
<Formal-output-parameters>  transfer  values  Into  the  <subroutlne-body> 
and  also  transfer  values  from  the  <subroutlne-body>  back  to  the 
correspond  1 ng  <ac tual-ou tput-parame t ers> . 

If  a  formal  parameter  Is  a  <data-name>  It  may  be  bound  to  the 
corresponding  actual  parameter  In  any  of  the  following  ways:  by 
reference,  by  value,  by  result,  or  by  value-result.  Reference  binding 
means  that  the  actual  parameter  and  the  formal  parameter  denote  the  same 
physical  object.  Any  change  In  the  value  of  the  formal  parameter 
entails  an  Immediate  change  In  the  value  of  the  actual  parameter  and 
vlcc-versa.  Value-result  binding  means  that  the  formal  parameter 
denotes  a  separate  data  object,  assigned  the  value  of  the  actual 
parameter  on  entry  to  the  subroutine,  and  used  to  assign  Its  value  to 
the  actual  parameter  on  normal  exit  from  the  subroutine.  Since  It  Is  a 
separate  data  object  there  Is  no  interaction  between  it  and  the  actual 
parameter  during  execution  of  the  subroutine.  Value  binding  Is  similar 
except  the  actual  parameter  is  not  modified  on  exit  from  the  subroutine. 
Result  binding  leaves  the  value  of  the  formal  parameter  undefined  on 
entry  to  the  subroutine  but  is  otherwise  like  value-result  binding. 

Standard  rules  for  types  of  binding  Indicate  the  effect  normally 
requ 1  red : 

Reference  binding  shall  be  used  for  blocks,  tables,  and  for 
entries  of  all  except  tight  tables. 

Value  binding  shall  be  used  for  input  items  and  tight  table 
entries . 

Value-result  binding  shall  be  used  for  output  items  and  tight  table 
ent  rles . 


Explicit  <parameter-blndlng>  specification  affects  these  rules  as 
follows ; 


BYREF  -  reference  binding  is  required.  If  the  actual  parameter 
cannot  be  passed  by  reference  (such  as  a  badly  aligned 
table  Item),  the  compiler  shall  allocate  a  temporary 
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variable,  use  value  or  value-result  binding  as 
appropriate  to  pass  the  parameter  between  its  actual 
location  and  the  temporary  variable,  and  pass  the 
temporary  variable  by  reference  to  the  subroutine. 

BYVAL  -  reference  Is  prohibited.  The  parameter  shall  be  passed 
by  value  or  value-result  as  appropriate. 

BYRES  -  result  binding  Is  required. 

An  Implementation  may  optimize  binding  methods  provided  It 
guarantees  required  results  both  In  parameters  passed  and  In  side 
effects,  if  any. 

If  the  <fonnal-lnput-parameter>  Is  a  <statement-name> ,  a  GOTO 
statement  with  that  name  as  a  target  will  cause  the  subroutine  to  be 
exited  without  setting  any  of  the  value- result  parameters.  Execution 
will  resume  at  the  statement  named  In  the  actual  parameter  as  though  the 
GOTO  statement  had  been  executed  at  the  point  of  the  subroutine  call. 

If  the  <formal~lnput-parameter>  Is  a  <subroutIne-naroe>  the  <name> 
of  the  corresponding  actual  parameter  determines  which  <subroutine- 
deflnitlon>  to  associate  with  the  formal  parameter's 
<subroutlne-declaratlon>  on  each  call.  A  call  to  that  subroutine  via 
the  formal  parameter  <narae>  will  be  treated  as  If  the  corresponding 
actual  parameter  subroutine  had  been  called  from  the  same  environment  In 
which  <subrout ine-name>  was  originally  specified  as  an 
<actual-lnput-parameter> . 

The  order  of  evaluation  of  actual  parameters  is  unspecified. 

In  the  absence  of  an  <lnterference-dlrectlve>,  no  interference  Is 
assumed  within  the  subroutine  between  actual  parameter  data  and  formal 
table  or  block  parameters,  or  between  actual  parameters  and  variables 
accessed  directly  from  within  the  subroutine. 

Constraints  : 


The  same  name  must  not  appear  more  than  once  in  any 
<formal-parame  ter-llst>. 

A  <formal-l nput-parameter>  cannot  be  used  in  a  context  In  which  Its 
value  can  be  altered  (e.g.,  as  a  target  in  an  <assignment-statement>) . 

Names  of  data  declared  as  formal  parameters  must  not  be  used  in 
<ove r lay-dec  la ratlons>. 

Declarations  of  formal  parameters  roust  not  contain  <allocatlon- 
speclfiers>  or  presets. 
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<External-declaratlons>  of  formal  parameters  are  not  permitted. 

The  <subroutlne-def Inl t lon>  (and  <subroutlne-declaratlon> ,  If  one 
Is  present)  must  contain  an  explicit  <dec la  rat i on>  for  each  <name>  In 
the  <formal-parameter-llsc>. 

For  any  subroutine  call,  the  number  of  formal  and  actual  Input 
parameters  must  be  the  same,  and  the  number  of  formal  and  actual  output 
parameters  must  be  the  same. 

Declarations  of  formal  parameters  cannot  be  <constant-declaratlons> 
or  <type-declarat tons> . 

For  all  table  parameters,  the  types  of  the  formal  parameters  and 
those  of  the  corresponding  actual  parameters  must  be  equivalent  (see 
Section  7.0).  This  requirement  extends  to  the  types  and  associated 
attributes  of  all  components,  and  their  allocation  order.  For  all  Item 
parameters,  the  rules  for  implicit  attribute  conversion  apply  (see 
Section  7.0).  Block  parameters  match  under  the  following  conditions: 
(1)  the  type  and  textual  order  of  the  components  match  exactly;  (2)  an 
.'ORDER  directive  Is  either  present  In  both  <block-body-parts>  or  absent 
In  both  <block-body-parts>;  and  (3)  <overlay-declarations>  In  both 
blocks  have  the  same  effect. 

The  actual  parameter  corresponding  to  a  formal  Input  parameter 
<statement-name>  must  be  a  <stateraent-name>.  The  actual  parameter 
corresponding  to  a  formal  Input  parameter  <subroutlne-name>  must  be  the 
name  of  a  subroutine.  Parameter  types  and  return  value  types  of  formal 
and  actual  subroutines  must  match  exactly. 

BYRES  binding  must  not  be  specified  for  Input  parameters. 

3.4  INblNE  PROCEDURES  AND  FUNCTIONS 
Syntax : 

<lnllne-declaration>  ::=  INLINE 

<subrout i ne-name> , . . .  ;  (3.1) 


Semantics : 


An  <inllne-declaratlon>  causes  the  object  code  for  the  bodies  of 
each  of  the  designated  subroutines  to  be  Inserted  at  the  point  of  every 
call  of  that  subroutine  within  the  scope  containing  the 
<inllne-declaratlon> .  This  will  be  done  Instead  of  inserting  code  for 
calling  a  remote  subroutine  body. 
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The  effect  of  the  <lnllne-declaratlon>  extends  for  just  the  name 
scope  In  which  the  <lnl lne-declaratlon>  appears.  It  does  not  affect 
calls  appearing  In  enclosing  scopes. 

If  any  actual  parameters  to  inline  subroutines  are  constants, 
Inline  expansion  may  cause  some  formulas  In  the  <6ubroutlne-bodl es>  to 
become  evaluable  at  compile  time.  Complle-tlme  evaluation  of  these 
formulas  will  be  performed  and  any  corresponding  error  messages  will  be 
generated  as  though  the  programmer  had  written  those  formulas  directly. 
Except  for  the  effects  of  complle-tlme  evaluation,  the  semantics  of 
Inline  subroutine  expansion  are  Identical  to  the  semantics  of  the 
normal,  remote  subroutine  call  mechanism. 

Inline  subroutines  may  themselves  contain  (possibly  Inline) 
subroutine  calls,  but  they  may  not  contain  nested  subroutine 
def Inlt Ions . 

Inline  subroutine  names  may  be  used  as  actual  parameters,  but  a 
call  to  the  matching  formal  parameter  name  will  result  In  a  closed 
rather  than  Inline  Invocation  (even  If  the  actual  parameter  Is  an  Inline 
subrout ine ) . 

Constraints : 

Names  of  subroutines  whose  definitions  appear  In  another  module 
cannot  be  used  in  <inlIne-declaratlons>. 

Formal  parameters  cannot  be  declared  to  be  Inline. 

It  Is  Illegal  to  have  an  inline  subroutine  Invocation  of  a 
subroutine  that  is  already  being  expanded  Inline. 

Fomial  parameters  of  Inline  subroutines  cannot  be  used  in  contexts 
where  the  syntax  requires  a  complle-tlme  formula. 

3.5  MACHINE-SPECIFIC  PROCEDURES  AND  FUNCTIONS 
Semantics : 


Each  compiler  implementation  may  provide  a  set  of  procedures  and 
functions  that  are  Intrinsically  recognized  by  the  compiler.  These 
procedures  and  functions  shall  typically  encompass  operations  that  are 
not  directly  provided  by  the  language.  They  may  be  Implemented  as 
subroutines  or  via  inline  code,  whichever  is  suitable.  The  use  of 
inline  code  is  particularly  suitable  as  a  vehicle  for  invoking  single 
machine  instructions  which  are  peculiar  to  the  target  machine. 


r>9 

113 


MIL-STD-1589B  (USAF) 
06  June  1980 


In  general,  a  subroutine  will  be  provided  for  machine  Instructions 
whose  execution  would  otherwise  be  unobtainable  through  the  language. 
It  Is  not  Intended  that  every  target  machine  Instruction  be  supported  as 
a  machine-specific  procedure  or  function.  Subroutines  will,  however,  be 
provided  for  machine-sped f Ic  Instructions  whose  moaning  Is  not 
expressible  In  the  language  (e.g.,  "load  status  word",  "test  condition 
code"),  as  well  as  Instructions  for  which  a  J73  subroutine  could  be 
written  but  which  are  directly  Implemented  by  target-machine 
Instructions  (e.g.,  "sine",  "matrix  multiply",  or  "rotate  length-32 
bitstring",  etc.).  Such  subroutines  will  be  defined  at  system  scope  and 
hence  their  names  will  be  redeflnable  In  Inner  scopes.  Such  subroutines 
will  be  Invoked  in  the  same  way  as  other  subroutines  (see  Sections  4.5 
and  6.3).  The  particular  parameters  to  such  subroutines  are 
Subroutine-dependent . 

Implementation  requirements  for  each  such  subroutine  Include 
specif icatlon  of  the  operation  to  be  performed  and  of  the  rules  for  each 
formal  parameter,  including  both  Its  JOVIAL  attributes  and  how  it  is 
used.  The  compiler  shall  generate  coda  to  use  the  parameters  and 
perform  the  specified  operation. 
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4.0  STATEMENTS 
Syntax; 


<sta  tement> 

•  •  a 

•  • 

[ <dlrect ive> .  .  .  ]  [<label>...] 

<slinple-s  tatement> 

(9.0) 

1 

[<dlrectlve>. . .]  (<label>...] 

<compound-s tatement> 

(9.0) 

<slraple  -stateiiient> 

:  :  = 

<asslgnnient-stat  enient> 

(4.1) 

1 

<loop-stat  ement> 

(4.2) 

1 

<lf-statenient> 

(4.3) 

1 

<case-stat ement> 

(4.4) 

1 

<procedure-ca  1 1-s  t  a  t  einent> 

(4.5) 

1 

<return-statement> 

(4.6) 

1 

<goto-stat em*nt> 

(4.7) 

1 

<exi t-statement> 

(4.8) 

1 

<stop-stateiiient> 

(4.9) 

1 

<abort-sta  teD)ent> 

(4.10) 

I 

<nul 1-s tat  eraent> 

<null-statement> 

:  :  = 

9 

1 

begin  [<label>...] 

END 

<label> 

:  :  = 

<statenient-name>  ; 

<s  tateinent-name> 

:  :  = 

<nanie> 

(8.2.1) 

<compound-statenient> 

:  :  = 

BEGIN  <statenient>.  .  . 
[<directlve>  .  • . ) 

(9.0) 

{<label>...)  END 
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Semantics : 


<Statements>  are  the  means  by  which  computational  algorithms  are 
specified.  They  control  the  execution  of  the  <complete-program>. 

A  <compound-statement>  permits  a  sequence  of  <statement6>  to  be 
used  In  contexts  requiring  a  single  <statement>. 

A  <null-statement>  results  In  no  operation. 

A  <label>  Is  used  to  attach  a  <6tatement-name>  to  a  <statement>.  A 

the  END  of  a  <compound-statement>  or 
as  If  a  no  operation  <staleraent>  followed 


::=  <varlable-l 1 st> 

<formula>  ;  (5.0) 

: :=  <varlable> , . . .  (6.1) 

Semantics : 


<label>  that  Is  attached  to 
<null-statcment>  Is  treated 
the  <label>. 

4.1  ASSIGNMENT  STATEMENTS 
Syntax ; 

<asslgnment-statement> 

<varlable-list> 


An  <asslgnment-statement>  causes  the  value  of  the  <formula>  to  the 
right  of  the  equal  sign  to  be  assigned  to  the  <variables>  to  the  left  of 
the  equal  sign. 

In  performing  the  assignment,  the  <formula>  Is  evaluated  first. 
Then,  the  leftmost  variable  is  evaluated  and  the  value  of  the  formula  Is 
assigned  to  that  variable.  Next,  the  second-to-the-lef t  variable  Is 
evaluated  and  the  value  of  the  formula  Is  assigned  to  It.  This  sequence 
of  evaluations  continues  until  the  list  of  variables  is  exhausted.  If 
necessary  and  permitted  (see  Section  7.0),  the  value  of  the  formula  is 
implicitly  converted  to  the  type  of  the  variable  being  assigned  to.  For 
numeric  values,  the  value  Is  rounded  or  truncated  according  to  the 
<round-or-tiuncate>  attribute  of  each  variable  being  assigned  to  (see 
Sections  2. 1.1. 2  and  2. 1.1. 3). 

Constraints ; 

The  type  of  the  <formula>  must  match  or  be  implicitly  convertible 
to  that  of  each  of  the  <varlables>  according  to  the  rules  given  in 
Section  7.0. 
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All  <varlables>  In  the  <varlable-list>  must  be  of  the  same  type 
class. 

None  of  the  <varlab]es>  may  be  <fortnal-lnput-paran)eters>. 

Note ; 

Assignment  semantics  and  constraints  apply  to  presets  (Section 
2.1.6),  assignments  to  <control-ltems>  In  <loop-statement6>  (Section 

4.2) ,  and  some  types  of  actual/formal  parameter  correspondence  (Section 

3.3) . 


Since  the  Implemented  precision  of  packed  fixed  point  table  Items 
may  be  less  than  the  Implemented  precision  of  an  unpacked  Item  having 
the  same  fixed  type,  and  since  rounding  and  truncation  are  performed 
with  respect  to  Implemented  precision,  assignment  to  packed  table  Items 
may  change  the  value  being  assigned  (see  Section  7.0). 


4.2  LOOP  STATEMENTS 
Syntax; 


<loop-statement> 

<loop-type> 

<controlled-statement> 

<loop-type> 

:  :  = 

<whlle-clause> 

1 

<for-clause> 

<controlled-statement> 

:  :  = 

<statement> 

<whlle-c lause> 

:  :  = 

WHILE  <bool ean-f o rmula>  ; 

(5.2.2) 

<for-clause> 

:  :  = 

FOR  <control-ltem>  : 

<conl rol-c lause>  ; 

<cont  rol-1 tem> 

:  := 

<control-var 1 able> 

1 

<c on tro 1-let ter> 

<cont  rol-varlable> 

:  :  = 

< 1 tem-naroe> 

(2.1.1) 

<control-le tter> 

;  ;  = 

<lette’-> 

(8.1) 

<cont  rol-clause> 

<lnltlal-value> 

(<continua( 1 on>] 
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<lnl tlal-value>  ; ;= 

<contlnuatlon> 

I 

<by-or-then-phrase>  ::= 

I 

<by-phrase>  :  ;  = 

<by-forBiula>  ::  = 

<then-pbrase>  :  :  = 

<whl le-phrase>  :  :  = 

Semantics; 

A  <loop-statement>  provides 
statement . 


<formula>  (5.0) 

<by-or'then  plirase> 

( <whl  le-p1irase>  ] 

<whlle-pbrase> 

[<by--or-then-phrase> ) 

<by-phrase> 

<tben-phrase> 

BY  <by-formula> 

<numerlc-forrau]a>  (5.1) 

THEN  <fomiula>  (5.0) 

VfHlLE  <boolean-f  orniul  a>  (5.2.2) 

for  the  Iterative  execution  of  a 


If  the  <whlle-clause>  form  of  the  <1 oop-statement>  Is  used,  the 
<controlled-statement>  Is  executed  until  the  value  of  the 
<boolean-formula>  becomes  FALSE.  The  <boolcan-formula>  Is  evaluated 
before  each  Iteration. 

If  the  <for-clause>  form  Is  used,  the  value  of  <control-l tem> 
determines  the  number  of  Iterations.  If  the  <cont rol-i tem>  Is  an 
<ltem-name>.  Its  type  Is  as  specified  in  Its  <declaratlon>,  and  that 
<ltem-name>  may  be  used  for  purposes  other  than  loop  control  before  and 
after  the  loop.  After  execution  of  the  loop  concludes,  the  value  of  the 
<ltem-name>  is  the  last  value  it  received  in  the  <loop-stateroent>.  If 
the  <cont rol-i tein>  is  a  <letter>,  the  <for-clause>  constitutes  an 
implicit  declaration  of  the  <cont rol-1 tera> ,  and  Its  value  is 
inaccessible  prior  to  the  start  of  the  <loop-statement>  and  after  the 
<loop-s ta tement>  concludes.  Its  type  is  that  of  the  <i ni t ial-value>  . 
Its  scope  is  the  <loop-statement>  Itself;  hence,  another  loop  statement 
may  use  the  same  <letter>  as  a  <control-i tem>  (except  as  prohibited  in 
Constraints)  and  no  conflict  will  result. 

The  actions  of  the  <loop-stateDient>  with  a  <for-clause>  are  as 
specified  by  the  following  algorithm: 

Step  1:  The  <lnltlal-value>  Is  evaluated  and  assigned  to  the 
<c on t  rol-1 tera> . 
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Step  2:  The  <boolean-fonnula>  in  the  <whlle-phrase>  (If 
present)  Is  evaluated.  If  It  Is  FAI.SE,  execution  of 
the  <loop-statement>  concludes. 

Step  5:  The  <cont rolled -statement>  Is  executed. 

Step  A;  The  forinul*  In  the  <by-or-then-phrase>  (If  present) 
Is  evaluated.  The  value  for  the  <by-fonnula>  (If 
present)  Is  added  to  the  <cont rol-1 tom> .  The  value 
of  the  <then-forniula>  (if  present)  is  assigned  to 
the  <cont rol-1 tem> .  Execution  continues  at  Step  2. 

The  <control-l  teni>  may  be  used  In  a  <formula>  In  the  <control- 
clause>  and  In  the  <controlled-statement>. 

Execution  of  the  <loop-statement>  concludes  If  control  Is  passed  to 
another  statement  by  means  of  a  GOTO,  RETURN,  EXIT,  STOP,  or  ABORT 
statement . 

Constraints: 


If  the  <control-i tem>  is  a  <letter>.  It  nust  not  be  used  In  the 
<controlled-statement>  or  <control-clause>  in  any  context  in  which  its 
value  can  be  altered  (e.g.,  as  an  <actual-output-paratDeter>  or  as  a 
target  in  an  <asslgnment-staten)ent>) .  If  the  <cont rol-i tem>  is  an 
<lteni-name> ,  asslgnmer.'ts  to  it  in  the  <controlled-statement>  are  not 
prohibited,  but  .will  result  in  a  warning  message. 

A  <label>  in  a  <controlled-statement>  cannot  be  used  as  the 
<statcment-name>  in  a  <goto-statement>  or  <abort-phrase>  that  is  outside 
the  <cont rolled-stateraent>  or  as  an  <actual-input-parameter>  in  a 
subroutine  Invocation  that  is  outside  the  <controlled-statement>. 

The  <lnitial-value> ,  <by-formula>  and  <then-f ormula>  must  match  or 
be  Implicitly  convertible  to  the  type  of  the  <cont rol-i tem>  (see  Section 
7.0).  Further,  the  sum  of  the  <by-formula>  and  the  <control-ltem>  must 
match  or  be  implicitly  convertible  to  the  type  of  the  <control-I tem> . 
The  <lnitlal-value>  cannot  be  of  type  table. 

The  <by-forraula>  (if  present)  roust  have  type  and  value  such  that  it 
may  be  legally  added  to  the  <control-ltem>  according  to  the  ryles  of 
Sections  5.1.1,  5.1.2,  and  5.1.3. 

If  the  <control-ltem>  is  a  <control-l et ter> ,  the  <lnitlal-value> 
must  not  be  a  <status-constant>  that  belongs  to  more  than  one  type 
(unless  the  <status-constant>  is  disambiguated  by  an  explicit  conversion 
—  see  Section  7). 

The  <control-letter>  in  a  <loop-statement>  may  not  be  the  same  as 
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the  <cont rol-let ter>  of  any  enclosing  <loop-statement> . 

A  <bi t-f onnula>  cannot  be  Implicitly  converted  to  the 
<boolean-f  ormula>  In  a  <wVit  le-phraEe>. 


4.3  IF  STATEMENTS 
Syntax ; 


<1 f-statement> 

:  ;=  IF  <boolean-f oni)ula>  ; 
<condl  t  Iona  1-s  ta  te;nent> 

[ <el se-c 1 ause>  ) 

(5.2. 

<condi tional-statcment> 

:  :=  <statement> 

(4.0) 

<el sc-c lause> 

:  [<dl rect 1 ve> . . . ) 

(9.0) 

ELSE  <statement> 

(4.0) 

Sc-mant  Ics : 

An  <i f-s tat ement>  provides  for  conditional  execution  of  a  statement 
depending  on  the  value  of  its  <boolean-forn)ul  a> . 

rf  the  value  of  the  <boo3ean-fon3)ula>  Is  TRUE,  the 
<condi  t ional-stateDient>  Is  executed  and  the  <statement>  In  the  ELSE 
clause  (if  any)  Is  not  executed. 

If  the  valtie  of  the  <boolean-forniula>  Is  FALSE,  the  <statement>  In 
I  he  <"f' I  se -c  1  ause>  (if  present)  Is  executed  rather  than  the 
■^contl  i  t  i  ona  1  -  s  t a  t  einent >  .  In  the  event  of  nested  <  1  f -s  t  a t emenl s>  ,  an 
ELSE  issociates  with  the  Innermost  unmatched  IF. 

If  the  vboo lean-f ormu 1 a>  has  a  value  that  Is  known  at  compile  time, 
.onditional  (  oin  (i  i  1  a  I  i  on  (see  Section  1.2.4)  will  occur. 

"on  s  t  r  a  i  n  l  s  : 

<L.ibels>  throughout  i  cope  must  be  unicjue,  even  if  portions  of  the 
text  within  the  scope  are  unselected  as  a  result  of  conditional 
I  om  p  i  1  .a  :  ion. 

<Dlrectives>  preceding  ELSE  must  be  text  directives  (Section  9.2) 
or  listing  directives  (Section  9.7). 


A 
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<boolean-forniula>  In  an  <lf-statement>. 
Note : 


<Labe]s>  In  the  <condl tlonal-6tatement>  and  In  the  <else-clau6e> 
are  In  the  same  scope  as  the  <lf-statement>  Itself. 


4.4  CASE  STATEMENTS 
Syntax; 

<case-statement> 


<case-selector-forinula> 


<case-body> 
<case-alternat lve> 


<default--option> 


<case-index-group> 
<case-l ndex> 


::=  CASE 

<case-select  or-formiila> 
{<di rect ive>  . . . ) 

BEGIN  <case-body> 
(<label>..,)  END 

: :=  <lnteger-formula> 

I  <blt-formula> 

1  <character-formula> 

(  <status-formula> 

: :=  <case-alternat lve> . . . 

::=  (  <dlrective>. . .  ] 

<case-index-group> 
<stateroent> 

[FALLTHRU] 


(9.0) 

(4.0) 

(5.1.1) 

(5.2) 

(5.3) 

(5.4) 

(9.0) 

(4.0) 


I  <default-optIon> 

::=  (<directive>. . . )  (9.0) 

(  DEFAULT  )  : 

<statement>  (4.0) 

{FALLTHRU] 

;:=  (  <case-index> , . . .  )  ; 

::=  <cotiiplle-tirae-integer-forinula>  (5.1.1) 

I  <complle-tlme-blt-fonnula>  (5.1.2) 

I  <compl le-t ime-character-  (5.1.3) 

fonnula> 
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1  <r ompl  1  e-t  liiie-s t a t us- f o rmiila>  (5.4) 

I  < lower-bound>  :  (2. 1.2.1) 

<uiiper-l>tain(i>  (2. 1.2.1) 


Stmant Ics : 

VOiereas  an  <  1  f-sra  i  tiaent  >  provides  for  the  ojjtltaial  I'Xf-c  u  t  i  oo  of 
eltlier  of  two  statements,  a  <<:<isc-s  t  at  etaent  >  piovfdes  for  a  cliolce  o‘ 
executing  one  or  more  of  a  number  of  st  at  ei-icnr  s .  (TVje  possible  cIujIcos 
are  represented  Ly  the  various  <rasc -a  1 1 e r na t  1  v(-s> )  . 

The  particular  <case-alternat ive>  Is  selected  according  to  rlie 
value  of  <case-sel ec t or-f ormula> .  Several  values  of  the  <casc-sel ector- 
formula>  may  select  the  same  <case-a 1 1 erna 1 1 ve>  . 

With  the  exception  of  the  <def aul t-op t 1 on> ,  each  <case-al t ernat ive> 
Is  headed  by  a  <case- 1 ndex-group>  that  designates  the  possible  values  of 
the  <case-selector-f ormul a>  that  after  being  Implicitly  converted  (if 
necessary)  to  the  type  of  the  <casc-sel ec t or- f o rmul a> ,  cause  that 
particular  <case-alternatlve>  to  be  selected  for  execution.  Each 
<case-index>  can  designate  either  a  single  value  or,  for  Integer  and 
status  selector  types,  a  closed  range  of  values  bounded  by  <lower-bound> 
and  <upper-bound>. 

If  the  value  of  the  <case-selector-forraula>  does  not  correspond  to 
a  <case-lndex>  value,  the  <statement>  In  the  <default-option>  Is 
execut  ed . 

If  FALLTHRU  is  not  present  after  a  selected  <s t a  I rment >  ,  execution 
of  the  <case-statement>  concludes  after  that  <statement>  is  executed. 
If  FALLTHRU  is  present  after  the  selected  <s t a t emen t > ,  the  <statemenr> 
In  the  textual ly-succeedlng  <case-a 1 t c rna t 1 ve>  Is  then  executed. 
Control  continues  to  "fall  through"  to  subsequent  <ca se-a 1 t e rna 1 1 ves>  , 
until  a  case-alternative  with  no  FALLTHRU  Is  executed  or  until  the  KND 
of  the  <case- s t a t enient>  has  been  reached. 

If  the  value  of  the  <case-selector-fornnila>  is  known  at  compile 
time,  conditional  compilation  (see  Section  1.2.4)  will  occur  for  all 
unselected  alternatives  that  cannot  be  leached  via  FALLTHRU  semantics. 

Constraint^: 

No  two  <case-a 1 t erna t 1 ves>  within  the  same  <ca se-s t a t ement >  can  be 
associated  with  Identical  <case-lndex>  values. 

If  a  <def aul t -opt  1 on>  is  not  present,  the  value  of  the 
<case-sel ec t or- f o rmu 1 a>  must  be  represented  by  a  <rase- 1 ndex>  . 
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The  types  of  each  formula  In  a  <case-lndex>  must  match  or  be 
Implicitly  convertible  to  that  of  the  <'case-se]ector-formula>  according 
to  the  rules  given  In  Section  7.0. 

If  the  <case-selector-formula>  Is  a  <status-fonnula> ,  a 
<case-lndex>  specifying  lower  and  upper  bounds  Is  legal  only  If  the 
status-  type  has  the  default  representation  (si-e  Section  2. 1.1. 6). 

The  <upper-bound>  In  a  <case-lndex>  must  be  greater  than  or  equal 
to  the  <'lower-bound>  . 

<Dlrectlves>  preceding  DEFAULT  or  <case-l ndex-groups>  must  be  text 
directives  (Section  9.27)  or  listing  directives  (Section  9.7). 

Within  a  <ca se-s t a t ement>  ,  at  most  one  <def aul t-opt lon>  may  be  used 
as  a  <case-al ternatl ve>  . 

Note : 


<Labels>  In  the  <default-optlon>  and  in  the  <case-a 1 ternat 1 ves>  are 
In  the  same  scope  as  the  <case-statement>  Itself.  Consequently,  control 
can  be  transferred  Into  or  between  case  statements. 


4.5  PROCEDURE  CALL  STATEMENTS 


Syntax; 

<procedure-call- 
s  t  a t  ement> 


<user-deflned-procedure- 

call> 


<ac tual -parameter-1 Is t> 


<ac t ua 1- In put-pa rameter> 


<user-defined-procedure-call> 

<'  machine- spec  1  f  1  c-procedure-ca  1 1> 

<procedure-name>  (3.1) 

(<actual-parameter-list>] 

( <abort-phrase> J  ; 

(  (<actual-Input-parameter>,  .  .  .  J 
(  :  <actual-output-parameter> ,  .  .  .  ]  ) 

<'formula>  (5.0) 

<"51  atement-name>  (4.0) 

<f unct lon-name>  (3.2) 


I  <procedure-name> 


(3.1) 
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1  <block-narae> 

(2.1.4) 

1  <block-dercf erence> 

(6.1) 

1  <nosted-block> 

<nested-block> 

: :=  <block-name> 

[<block-dereference>] 

(2.1.4) 

(6.1) 

<actual- output- 
pa  rame 1 er> 

: :=  <varlable> 

(6.1) 

I  <block-naroe> 

(2.1.4) 

1  <block-dereference> 

(6.1) 

1  <nes ted-block> 

<abort-phrase> 

::=  ABORT  <staterapnt-nan)e> 

(4.0) 

<machl ne-spec ific- 
procedure-cal 1> 

: :=  <procedure-name> 

( <actual-paramet er-1 i s t>  )  ; 

(3.1) 

Semantics: 

A  <procedure-call-statenicnt>  causes  invocation  of  a  procedure  and 
the  association  of  formal  parameters  with  actual  parameters  according  to 
the  rules  given  In  Section  3.3. 

A  <use r-de f 1 ned-procedure-cal 1>  causes  invocation  of  a  procedure 
defined  in  a  <proc edure-def 1 n i l i on> .  The  <abort-phrase>  Is  for  use  In 
connection  with  <abort-s t a t ement s> .  Its  semantics  are  explained  In 
Sect  ion  4.10. 

A  <machi ne-speci f lc-proredure-caH>  causes  invocation  of  a  machine- 
specific  procedure  (see  Section  3.5). 

A  <nested-block>  is  a  block  contained  In  another  block.  If  the 
<block-name>  was  declared  in  a  <bl ock-t ype-decl a ra r i on> ,  the  <block- 
dereference>  references  the  particular  block  from  which  the  nested  block 
is  to  be  obtained. 

Constraints: 

Actual  parameters  in  the  <procedure-ca 1 1-s tat ement >  must  match  the 
formal  parameters  of  the  called  procedure  in  ntimber,  kind,  and  parameter 
list  position,  according  to  the  rules  given  in  Section  3.3. 
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The  t  a  t  emc‘ n  t -narae>  In  an  ^abort-phrased  or 
<ac t ua 1— 1 nput — pa r aine t e rd  must  be  known  In  the  scope  In  which  the 
<procedu re-ca 1 1-s t a t omi*nt d  appears,  but  It  must  not  name  a  statement 
that  Is  In  anothf'r  module  or  In  an  (ncloslng  subrout  fne  or  that  was  In 
unselected  text  In  conditional  compilation.  It  cannot  be  the  name  of  a 
statement  that  Is  In  a  <cont rol led-s t a t ementd  unless  the 
<procedure-call-statementd  Itself  Is  within  that  same 
<controlled-statementd. 


A. 6  RKTURN  STATEMENTS 
Syntax : 


<return-statementd  RETURN  ; 

Semant 1 c  s  : 

The  effect  of  a  <r  ini  rn-s  I  a  t  enient  >  Is  to  terminate  the  execution  of 
a  subroutine,  sot  any  p.arainet  ers  that  have  va  1  ue- re  r.  u  1 1  semantics,  and 
return  control  to  the  point  following  the  invoatlon  of  the  subroutine. 
If  the  <return-statcmentd  is  In  a  <funct ion-bodyd ,  the  current  value  of 
the  <funct Ion-named  becomes  the  value  of  the  function  call. 

If  the  subroutine  containing  the  <re t urn-s t a l ementd  Is  nested 
within  any  enclosing  svibrout  1  nes ,  only  the  inuermcrst  subroutine  is 
t  ermi nat  od  . 

Const  ra I nt  : 

The  < r e t urn -s t a t ement >  can  appear  only  within  the  body  of  a 
subrout ine  . 


A. 7  COTO  STATEMENTS 
Syn  tax: 

<got  o-s  t  a  t  ementd  :;=  COTtl  <  s  t  a  t  ement -named  ;  (A.O) 

*'  i'  n  a  n  t  i  c  s  : 

A  <go t o-s t a t emen t d  causes  .ont rol  to  be  transferred  to  the 
statement  named  by  the  specified  <stat ement -named . 

Wlien  the  <  s  t  a  t  t  men  t -named  is  a  formal  s  t  a  t  emen  t -name  jrarameter,  the 

effect  'if  a  <go  t  o- '  a  t  e.'ie  n  I  >  is  eiju  i  1  eiit  "o  retc;  ring  from  the  current 

inErouliiie  invriia:!"!!  .I’hout  ■.■r'ing  va  1  .i<  -  i  •••■n  1  t  parameters  and  then 

xi  (  11 1  1  ng  a  got.  1 1  )  r  •  ei  I  '■  It  'he  pi  ■  i  ii ;  'i  i  the  subroutine's 
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Invocation, 

Constraints : 

The  <statenient-nanie>  raust  be  knovm  In  the  scope  In  which  the 
<goto-stateiiient>  appears.  Further,  the  <statement~name>  must  not  be  the 
<label>  of  a  statement  that  is  in  an  enclosing  subroutine  or  In  another 
module.  It  cannot  be  the  <label>  of  a  statement  In  a 

<cont rol 1 ed-statement>  unless  the  <goto-statenient>  is  Itself  within  that 
same  <controlled-statement>. 


A. 8  EXIT  STATEMENTS 
Syntax ; 


<exlt-statement>  :  :=•  EXIT  ; 

Semantics ; 

An  <exl t-stateinent>  causes  execution  of  the  immediately  enclosing 
<loop-statement>  ,to  terminate.  Its  effect  is  the  same  as  a  GOTO 
statement  that  transfers  control  out  of  the  <controlled-stateiT'’nt>  to 
the  point  following  the  end  of  the  <loop-statement> . 

Constraint : 


The  <exi t-statement>  can  appear  only  In  a  <cont rol led-stat ement> . 
It  .9  STOP  STATEMENTS 
Syntax: 

<stop-statement>  :  :=  STOP  [<lnteger~fonDula>  ]  ;  t.5.1.1) 

Semantics : 


A  <L- top-statement>  causes  execution  of  the  <complete-prograni>  to 
terminate.  If  a  <slop-s  tatenient>  is  executed  within  a 
<subrouti ne-body> ,  the  value-result  <actual-output-parameters>  of  any 
subroutine  whose  call  is  still  active  will  not  be  set. 

The  value  of  the  optional  <lnteger-f ormula>  In  a  <stop-statement> 
Is  made  available  to  the  environment  in  which  the  J73  program  is 
executing,  where  its  semantics  are  implementation-dependent.  Absence  of 
an  <lnteger-forraula>  implies  the  value  Is  not  determined. 
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Const  rain t : 

The  range  of  legal  values  of  the  <lnteger-fc :mula>  is  MINSTOP 
through  MAXSTOP. 

4.10  ABORT  STATEMENTS 
Syntax . 


<abort-statetnent>  :  :=  ABORT  ; 

Semant 1 cs : 


When  an  <al ort-s t a t ement>  is  executed,  control  passes  to  the 
statement  named  In  the  <ahort-phrase>  of  the  most  recently  executed, 
currently  active  <procedure-call-statemont>  that  has  an  <abort-phrase> , 
All  Intervening  subroutine  Invocations  are  terminated,  and  value-result 
parameters  of  such  subroutines  are  not  set.  If  there  Is  no 
current ly-act Ive  <procedure-call-statement>  that  has  an  <abort-phrase> , 
the  effect  of  the  <abort-statement>  Is  the  same  as  STOP. 
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5.0  FORMULAS 
Syn  t  ax  : 


<foniiula> 


<cotnpl  le  - 1  I  'no-  f  n  ran  1  a> 


nui'ie  r  i  r-  f  ormu  1  a> 

(5.1) 

hit  f  o 1  mu  1  a  S 

(5.2) 

‘  ha  '  at  T  (  I  - '  (1 1  i;-'.)'’  .iS 

(5.1) 

?  t  ;  US-1  c  rfai  1  a  > 

(5. A) 

)•(■  i  III  er-formul  a> 

(  •' .  5  ) 

•  .thl  e  -  f  ormu!  a> 

(  5.6) 

■  ■  -.ii  r  !  <  I  i  iiic  nu!M  1  ]  t. 

!oimuhi> 

(5.1  ) 

:  ■  i.  ’  hi  1  foe 

■  ' ,  1  . 1  > 

15.2") 

.  .  I'll-  t  i  .  •  1 . .  1  !  •  o  t  t 

I  -1  oi;-ai)a  > 

(5.3) 

1  :  .!■  pill  - 1  i  i:.e  I  1  a  I  Its  f 

’<11  "ill  1  .i5 

(  5  .  A  ) 

1  oi.ij  i  1  i.  t  i  mt  p  III.',. 

I o 1  mu  1 aS 

(5.5) 

Scraan  t  1  c  s  : 

<Formu]as>  ropro  ent  v,iliu>>..  (ach  <  1' i  ■ :  r  ■ ;  1  i  ;■  Lf.  with  it 

a  type  class  and  a  pp  t  cipi  i  a  t  o  at  t  i  i  tui  "s  . 

A  <c  f,.api  1  e- t  i  me  -  f  o  t  imi  1  a>  is  a  <fi'rniu],'>  wh.'so  valut  is  computed  and 

used  at  compile  time. 

All  comp  i  1  e-t  i  me  compulations  ai  e  |ietf<'iiMi;  usiiu;  the  r.mpe  and 

precision  parameters  of  lie  lai);i  f  luafLirn  . 

The  following  constructions  yield  v.ilues  at  lompile  i  i  me . 

1.  Data  declared  in  <  ■-  ons  t  ant  -  i  t  er.  ■  di  u  1  a  r  .i  i  i  ons>  ,  e\'ipi  for 
constant  items  whose  type  rla.  s-;  is  ,.c.  ir  ter. 

2.  The  functions  1. HOUND,  FIRST,  and  LAST,  regardless  of 

their  arguments;  the  function  DHOUND,  provided  its 
argument  is  ni  t  a  table  with  *  d  1  irniis  i  ons  ;  the  functions 
NKXT,  BIT,  HV'IK,  SMIFTL ,  SHI  HR,  ABS,  and  SON,  provided 
their  arguments  are  known  at  omplle  time;  the  futictlon 
NWDSKN,  provl'teH  i's  aigucient  does  not  contain  a 
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reference  to  a  name  whuse  declaration  Is  not  completed 
prior  to  the  point  at  which  the  function  appears;  the 
functions  BITSIZE,  BYTESIZE,  and  WORDSIZE,  provided  (1) 
their  arguments  are  known  at  compile  time,  (2)  their 
arguments  do  not  contain  references  to  names  whose 
declarations  are  not  completed  prior  to  the  points  at 
which  the  functions  appear,  and  (3)  tVieir  arguments  are 
not  blocks  and  are  not  tables  with  *  dimensions. 

3.  All  operator-operand  combinations  other  than 

dereferencing,  indexing,  and  assignment,  provided  the 
operands  have  values  that  are  known  at  compile  time. 

4.  All  type  conversions  except  REP,  provided  the  value  of 
the  <formula>  being  converted  Is  known  at  compile  time. 

5.  All  machine  parameters. 

6.  All  <status-constant s>. 

7.  All  <llterals>. 

The  following  values  are  not  known  at  ccjmplle  time: 

1.  Constant  items  whose  type  class  is  ]ointei. 

2.  Constant  tables  and  their  components. 

3.  All  data  declared  ■.ilhout  the  word  (tSSi^NT. 

4.  The  LOG  function,  regar<n<ss  of  its  .iiguiMnt;  tie 

function  UPOIIND,  If  its  a  i  ),■  n  e  n  l  is  a  l.'h’.e  with  * 

dimensions;  the  f  one  t  i  c.iis  M- ’>  T  ,  HIT,  HV  I  E  ,  ‘n- 1  f  :  I  , 

SiUrrR,  ARS,  .  nd  if  l'<v  h  .ve  n  .  .,r  c-n  ■•I'cr.s 

whose  value',  .a  c  i  <  •  t  E  O'  wn  at  ..■■•tie  t  i  .  >  '  f.e  f  n  ■  <  t  1 .  u 
NWDSKN,  if  its  p.um-'i  t  is  .i  ■..•-i-  ■'.•  .i..’.i,ftl  is 

not  c  ompl  e  t  'd  prill  to  t  hi  j  • .  i  u  t  ,i  I  u  I.  !  .  h  '  !  e  f  ur  .,  i  i  i  n 
appears;  llic  f.iiu'ions  r  r  :  i I  f  ,  ■•:.d  WtiHisi/E, 

if  (11  their  .i  r  goi-'i  I1 1  s  lave  v.il.o  ■'  -t  .le  not  V  nr. un  at 
r  omp  lie  time,  (?)  i  hi  i  r  ■  ■  ■  .  t  s  ’  1  ■.  n  m  i  i  c  i  n  <  ''S  to 

n.'une  s  whose  de ;  1  .i  r  .i  t  ;  ■  u  ■  :  •  ■  t  .  ,  '  •  •  .1  [j  :  i  .  r  to  t  i  le 

po  i  n  t  B  at  wti  i  ch  'he  :  ■  ■  '  .  ■  ■ '  ■  I  1  *  > '  .  '  r  (  ) )  t  lie  i  r 

a  rgnme  nt  s  are  t- 1  in  t  s  ■  r  '  .  t  '  i  .  i  t  h  *  . .  n  s  i .  ns  . 

5  ,  All  o pc  r  .1  f  o r  "O pe  t  .1  td  !  .  -  '  .  ns  t  t.,i  f  v e  <  r. e  or  roo r c 

e  V  a  1  o  .1 1  e  d  .  • ;  *■  i  i  o-i  •  -  '  .*  '•  o'"  it  i.  n .  .wti  it  c  omp  1 1  ’ 

t  i  me  . 
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6.  The  REP  conversion. 

7.  Any  value  arrived  at  via  a  <6tateraent>. 

8.  Dereferenced  or  subscripted  values. 

Any  value  known  at  compile  time  may  also  be  used  as  a  run-time 
value. 

5.1  NUMERIC  FORMULAS 
Syntax; 

<nuraerlc-fonnula>  :  :=  <1  nteger-formula>  (5.1.1) 

I  <floatlng-f ormula>  (5.1.2) 

I  <f lxed-fonnula>  (5.1.3) 

<compl le-t ime-numerlc-formu]a>: :=  <con:pl le-time-1 nteger-formula>  (5.1  . 1 ) 

I  <con)pile-t  Ime-f  loat  i  ng-f  ormul  a>(  5.1  .2  ) 

I  <complle-time-fixed-formula>  (5.1.3) 

Senant 1 cs  : 

A  <numeric-forraula>  represents  a  numeric  value. 

A  <r orapl le-t ime-numerlc-fortDula>  represents  a  numeric  value  that  Is 
knowm  at  compile  time  ( sie  Section  5.0). 

5.1.1  INTEGER  EORMULAS 
S^nt  ax : 

<lnt  f  ger-fornuila>  :  (<slgn>]  <lnteger-tena>  (8.3.1) 

I  <lnteger-f ormula> 

<plus-or-minus>  (8.2.3) 

<lnteger-tcrm> 

<1 nt fge r- t erm>  <lnteger-f actor> 

1  <lnteger-tenn> 

<multlply-d i vl de-or-mod> 
<lnteger-factor> 

7t, 

1  30 


(8.2.3) 
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<lnteger-factor> 

<lnteger-pr Ima  ry> 

1 

<lnteger-f actor>  ** 
<lnteger-prlmary> 

<lnteger-prlmary>  ::= 

<1 nt eger-11 1  eral> 

(8.3. 

1 

<1 Dteger-ma chine- 
pa  ra  mete  r> 

(l.A) 

1 

<lntegcr-variable> 

1 

<named-i nt eger-cons tant> 

1 

<intoger-functi on- cal 1> 

1 

(  <lnteger-form  ' a>  ) 

1 

<lnteger-converslon> 

(  <formula>  ) 

(7.0) 

(5.0) 

<lntege r-varlable>  ; 

<varlable> 

(6.1) 

<named-lnteger-constant>  ;:= 

<named-coustant> 

(6.2) 

<lnteger-f unctlon-call>  ::= 

<f unct i on-cal 1> 

(6.3) 

<complle-t lrae-lnteger-fonnula>  : := 

<int  eger-f  ormula> 

Semantics; 

An  <integer-formula>  represents  a  value  whose  type  class  is 
Integer,  l.e.,  S  or  U. 

The  Integer  operators  are  +,  *,  /,  MOD,  and  **,  which  denote 

addition,  subtraction,  multiplication,  division,  modulus,  and 
exponentiation,  respectively. 

The  type  of  a  formula  composed  of  an  integer  operator  and  two 
operands  is  S  NN-1 ,  where  NN  Is  the  actual  number  of  bits  that  would  be 
supplied  by  the  Implementation  for  a  signed  an  Integer 
<item-declaratlon>  whose  size  attribute  Is  the  larger  of  the  size 
attributes  of  the  two  operands.  The  type  of  an  <lnteger-foniiula> 
consisting  of  a  <slgn>  and  an  <integer-terTB>  is  S  NN-1,  where  NN  is  the 
actual  number  of  bits  that  would  be  supplied  for  a  signed  Integer 
<lten)-declaratlon>  whose  size  attribute  is  that  of  the  <integer-term> . 

The  quotient  of  two  Integers  is  first  computed  exactly  and  then 
truncated  to  an  integer  result.  Truncation  will  be  toward  zero. 
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The  modulus  of  two  Integers,  AA  MOD  BB,  Is  equivalent  to  AA  - 
(AA/BB)*BB. 

the  value  produced  by  Integer  exponentiation  to  a  positive  power  Is 
the  same  as  that  produced  by  repeated  multiplication. 

The  value  produced  by  Integer  exponentiation  to  a  negative  power  Is 
1  /  (base  **  abs  (power)  )  and  In  most  cases  Is  zero. 

Constraints : 


The  value  of  an  <lnteger-formula>  with  size  attribute  SS  must  lie 
In  the  range  MININT(SS)  through  MAXINT(SS). 

An  <lntcger-varlable> ,  <named-integer-constarit>,  or  Clnteger- 
functlon-call>  must  be  an  Integer  (S  or  U)  type. 

A  <complle-tlme-lnteger-formula>  must  be  i  <lnlcger-formula>  whose 
value  Is  known  at  complle-tlme  (see  Section  5.0). 

The  right  operand  of  /  and  MOD  must  be  non-zero. 

l^te : 

R  and  T  used  In  an  explicit  conversion  (see  Section  7.0)  do  not 
affect  the  value  of  Integer  division. 


5.1.2  FLOATING  FORMULAS 


Syntax; 

<f loat lng-fonnula> 


<f loatlng-tenn> 


<f loat ing- fact or> 


::=  l<sign>)  <f I  oat i ng-te rm>  (8.3.., 

I  <f]oat lng-foimula> 

<pl  us-or-mi nus>  (8.2.3) 

<f  loat ing- term> 

; :=  <f loatlng-factor> 

I  <f  loating-tenn> 

<multiply-cr-dlvlde>  (8.2.3) 

<f loat  j  ng-factor> 

:  <float Ing-prlmary> 

I  <f  lt)ating-factor> 

**  < f  loa 1 1 ng-pr lmary> 
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1 

<f)oatlng-factor> 

**  <1 nt eger-pr ima ry> 

(5.1  . 

<f loaf lrg-prlmary> 

<f 1  oat  1 ng-1 1 1  eral> 

(8.3. 

1 

<fl oa ting -machine- para me ter>(l. A) 

1 

<f loa 1 1 ng-va  rl able> 

1 

<named-f 1 oa t 1 ng-constant> 

1 

<f loa ting- f unc t ion-call> 

1 

(  <f  loat  Ing-foniiula>  ) 

1 

<floating-conver6ion> 

(  <formula>  ) 

(7.0) 

(5.0) 

< float ing-varlable> 

: 

<va  rl  ab'i  e> 

(6.1) 

<■  named- f  1  oa  t  i  ng  - cons  t ant  > 

: 

cnauif-d  -c  ons  t  ant  > 

(6.2) 

<f loa  t i ng-f  unc  t lon-cal 1> 

:  ;  = 

<f  unct 1 on-ca 1 1> 

(6.3) 

■compi le-ti me -float ing-formula> 

♦  •  a 

<f  loat  lng-foni!ula> 

Scmant i cs : 

A  <f  1  oa 1 1  ng-f onnvil a>  represents  a  value  whose  type  class  Is  float. 

The  floating  operators  are  +,  *,  /,  and  **,  which  denote 
addition,  subtraction,  multiplication,  division,  and  exponentiation 
respectively.  In  exponentiation  with  a  <f 1  oat Ing-factor> ,  a  floating 
value  Is  produced  in  all  cases. 

The  precision  attribute  of  a  <f 1 oa t 1 ng-f ormul a>  is  that  of  the 
formula's  most  precise  floating  operand.  The  operand  of  a 
<f loa t 1 ng-c onvers lon>  is  first  computed  according  to  the  default  rules, 
and  then  converted  to  the  specified  floating  type  (see  Section  7.0). 

For  floating  exponentiations  whose  right  operand  is  an 
<integer-prlniary>,  the  result  is  -(  ABS  (  left  operand  )  **  right 
operand  )  if  left  operand  is  negative  and  right  operand  is  odd;  (  ABS  ( 
left  operand)  **  right  operand  )  in  all  other  cases. 


Constraints : 
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The  value  of  a  <f loatlng-formula>  with  precision  PP  must  lie  In  the 
range  FLOATUNDERFLOW  (II)  through  MAXFLOAT  (II)  or  the  range  MINFLOAT 
(II)  through  -FLOATUNDERFLOW  (ll)  or  be  zero,  where  11 
IMPLFLOATPRFXISION(PP). 

A  <f loatlng-varlable> ,  <named-f loat 1 ng-constant> ,  or  <floatlng- 
funct Ion-call>  must  be  a  floating  type. 

A  <conipl  le-t  Ime-f  loa  t  lng-fonnula>  must  be  a  <floatlng-formula> 
whose  value  Is  known  at  compile  time  (see  Section  5.0). 

For  exponentiations  where  the  right  operand  Is  a 
<f loatlng-primary> ,  the  left  operand  must  not  be  negative. 

Exponentiation  of  an  Integer  base  to  a  floating  power  cannot  be 
performed.  Either  the  base  must  be  converted  to  floating  or  the  power 
must  be  converted  to  Integer. 

The  divisor  must  be  non-zero. 


Note : 


The  round  or  truncate  attribute  associated  with  variables  or 
constant  names  does  not  affect  the  computation  of  floating  formula 
results.  Floating  formulas  are  evaluated  In  an  implementation-dependent 
manner  with  respect  to  how  exact  results  are  approximated  to  the 
Implemented  precision. 


5.1.3  FIXED  FORMULAS 
Syntax ; 


<f ixed-formula> 


<f  lxed-tenn> 


:  :=  |<slgn>)  <fixed-term>  (8.3.1) 

I  <f ixed-formula> 

<plus-or-minus>  (8.2.3) 

<f ixed-term> 

:  <f Ixed-f actor> 

I  <fixed-term>  * 

<f lxed-factor> 

I  <lnteger-term>  *  (5.1.1) 

<f Ixed-f actor> 

I  <flxed-tenn> 

<mul t 1 ply-or-dl vlde>  (8.2.3) 
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<f lxed-factor> 

I 

I 

I 

I 

I 

I 

I 

I 

<f lxed-variable>  :  :  = 

<named-f lxed-constant>  : := 

<fixed-function-call>  ::= 

<coniplle-tlrae-flxed-fonnula>  :  :  = 
Semantics: 


<lnteger-factor>  (5.1.1) 

<flxed-llteral>  (8.3.1) 

<flxed-machlne-parameter>  (l.A) 

<f lxed-varlable> 

<named-f Ixed-cons  tant> 

<flxed-funct lon-call> 

(  <f lxed-formula>  ) 


<f ixed-convers ion>  (7.0) 

(  <fixed-tem>  / 

<f lxed-factor>  ) 

<f lxed-converslon>  (7.0) 

(  <lnteger-term>  / 

<f Ixcd-f actor>  ) 

<flxed-converslon>  (7.0) 

(  <fonnula>  )  (5.0) 

<varlable>  (6.1) 

<named-cons tant>  (6.2) 

<functlon-call>  (6.3) 

<f  lxed-foni)ula> 


A  <f lxed-forraula>  represents  a  fixed  point  value. 

The  fixed  point  operators  are  +,  *,  and  /,  which  denote 

addition,  subtraction,  multiplication,  and  division,  respectively.  The 
rules  specifying  the  result  type  of  these  operators  guarantee  that,  in 
general,  exact  results  are  produced.  The  specific  rules  are  given  below 
for  each  operator.  In  these  rulep,  Sn,  Fn,  and  Pn  refer  to  the  scale, 
fraction  part,  and  precision  of  an  operand  or  result  and  n  is  1,  2,  or  R 
to  indicate  the  f'frst  operand,  second  operand,  or  result,  respectively. 

For  addition  and  subtraction,  the  default  type  of  the  result  Is; 


SR  =  SI  -  S2 
FR  =  Max  (F1,F2) 
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PR  -  Max  (P1,P2) 

For  multiplication,  there  are  two  cases: 

1.  When  one  operand  Is  an  Integer,  the  result  scale  and 
precision  Is  that  produced  by  successive  addition,  l.e., 

SR  =■  Sa 

PR  =  Pa 

FR  =  Fa 

where  Sa,  Fa,  and  Pa  represent  the  scale,  fraction,  and 
precision  values  of  the  fixed  point  operand. 

2.  When  both  operands  are  fixed  point  types,  the  type  of  the 
resul t  Is : 

SR  =  SI  +  S2 

PR  --  PI  +  P2 

FR  =  FI  +  F2 

If  PR  is  larger  than  MAXFIXEDPRECISION  or  if  SR  does  not  He  In  the 
range  -  127  through  +  127,  then  the  product  must  be  explicitly  converted 
to  a  valid  fixed  point  scale  and  precision  (see  Section  7.0), 

For  division,  there  are  also  two  cases: 

1.  When  dividing  a  fixed  point  value  by  an  integer,  the 
scale  and  precision  of  the  result  are  the  scale  and 
precision  of  the  numerator.  Trtincation  will  be  toward 
zero. 

2.  When  both  operands  are  fixed  point  values  or  when  an 
integer  Is  divided  by  a  fixed  point  value,  the  result  is 
exact  and  must  be  explicitly  converted  to  a  programmer 
specified  scale  and  precision  (see  Section  7.0). 

The  default  result  type  of  a  <f lxed-formula>  containing  a  <sign>  as 
a  prefix  operator  is  the  type  of  the  operand. 

The  result  type  of  a  <flxed-factor>  that  is  a  <f lxed-variable>, 
<named-f ixed-constant> ,  or  <f ixed-f unctlon-cal 1>  Is  the  type  specified 
in  their  respective  variable,  constant,  or  function  declarations. 

The  type  of  a  <f lxed-llteral>  Is  contextually  determined  (see 
Section  8.3.1). 

The  result  type  of  a  <f 1 xed-f ormula>  enclosed  in  parentheses  Is  the 
type  of  tiie  enclosed  <f lxed-formula>. 
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The  result  type  of  a  <f ixed-factor>  containing  a  <f lxed-converslon> 
Is  the  type  specified  by  the  <f lxed-converslon> .  If  the  operand  of  the 
<f  lxed-coiiverslon>  is  a  <flxed-tenn>  or  <f  lxcd-formu]a> ,  the  Infix  or 
unary  operator  Is  evaluated  exactly,  and  the  mathematically-defined 
result  Is  converted  to  the  specified  fixed  type. 

Constraints ; 

Except  for  the  operand  of  a  <f ixcd-ccnverslon>,  the  value  of  a 
<f lxed-formula>  whose  scale  Is  SS  and  whose  fraction  attribute  Is  FF 
must  lie  In  the  range  M1NFIXED(SS,PP-SS)  through  MAXF1XED( SS ,PP-SS) , 
where  PP  =  1MPLF1XEDP8EC1S10N  (SS,FF). 

A  <f lxed-varlable>  ,  <named-f ixed-constant> ,  and  <f  1  xed-f unc t lon- 
call>  must  have  been  declared  as  fixed  typos. 

Operands  of  fixed  point  addition  or  subtraction  must  have  identical 
scales  . 

A  <complle-tlme-f lxed-formula>  must  be  a  <f lxed-formula>  whose 
value  Is  known  at  compile  time  (see  Section  5.0). 

The  divisor  must  be  non-zero. 


Note ; 

MOD  and  **  a  3  not  defined  for  fixed  point  operands. 

5.2  BIT  FORMULAS 
Syntax ; 

<bi t-f o rmula>  : := 

I 

<loglcal-operand>  : := 

I 

<bl t-primary>  ::= 

I 
I 


<.ioglcal-operand> 

{<loglcal-contl nua t ion> ] 

NOT  <loglcal-operand> 

(5.2.1) 

(8.3.2) 

(8.3.3) 

<bl t-varl able> 


<bl t-pr lmary> 
<relatIonal-expressl on> 
<bi t-1 1 teral> 
<boolean-li teral> 


83 

137 


r 


M1L-STD-1589B  (USAF) 
06  June  1980 


1 

<named-bl t-constant> 

1 

<bl t-funct lon-call> 

1 

(  <bl t-f ormula>  ) 

1 

<blt-converslon> 

(  <formula>  ) 

(7.0) 

(5.0) 

<logical-cont Inuat  i  on> 

• 

<and-contlnuatlon> .  , . 

1 

<or-contlnuatlon>.  . . 

1 

<xor-cont Inua t lon>  .  . . 

1 

<eqv-contlnua  t lon>  .  . . 

<and-cont Inuat Ion> 

:  :  = 

AND  < log! cal-operand> 

<or-cont inuat lon> 

:  ;  = 

OR  <loglcal  operand> 

<xor-cont inuat ion> 

:  :  = 

XOR  <1 oglcal-operand> 

<eqv-cont I nuatlon> 

:  :  = 

EQV  <logical-operand> 

<bl t-variable> 

:  :  = 

<varlable> 

(6.1) 

<named-blt-constant> 

:  :  = 

<named-constant> 

(6.2) 

<bit-function-call> 

:  :  = 

<function-ca]l> 

(6.3) 

<corapl  le-t  ime-bl  t-f  orTnula> 

:  :  = 

<bl t- f  ormul a> 

Sem antics : 

A  <bi t-f orn)ula>  represents  a  value  whose  type  class  is  bit.  Its 
size  is  the  number  of  bits  comprising  its  value. 

If  the  <bl t-fortDula>  is  composed  of  <1 oglcal-operands>  and  one  or 
more  of  the  logical  operators  AND,  OR,  XOR,  and  EQV,  the  size  of  the 
result  is  the  size  of  the  longest  operand.  Shorter  operands  are  padded 
on  the  left  with  zeros  as  necessary.  Note  that  the  syntax  requires 
explicit  parentheses  for  all  <blt-formulas>  containing  two  or  more  of 
these  operators,  unless  the  operators  are  identical. 

NOT  produces  a  value  that  is  the  logical  complement  of  its  operand. 
AND,  OR  (inclusive  or),,  XOR  (exclusive  or),  and  EQV  (equivalence) 
perform  their  usual  logical  function  on  their  two  operands  on  a 
bit-by-bit  basis.  If  both  operands  have  a  size  of  one  bit  and  the  value 
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of  the  left  operand  Is  such  that  the  result  of  the  operator  can  be 
determined,  evaluation  Is  "short-circuited",  l.e,,  the  right  opeiand 
will  not  be  evaluated  and  need  only  satisfy  semantic  constialnts  that 
can  always,  even  In  the  most  general  case,  be  verified  without 
evaluating  the  operand  (e.g.,  the  operand  need  not  satisfy  the  division 
by  zero  constraint  if  It  Is  not  evaluated). 

Constraints : 


A  <bl t-varlable>  must  be  a  <varlable>  whose  type  class  Is  bit. 

A  <named-blt-constant>  must  be  a  <named-constant>  whose  type  class 
Is  bit. 

A  <blt-functlon-call>  must  be  a  <functlon-call>  whose  result  value 
Is  bit. 

A  <compl le-tlme-blt-formula>  must  be  a  <bl t-f ormula>  whose  value  is 
known  at  compile  time  (see  Section  5.0). 


5.2.1  RELATIONAL  EXPRESSIONS 


Syntax ; 

<rela t lonal-expressIon> 


:  :=  <lnteger-formula> 

<relatlonal-operat or> 

<intege  r-f  ormula> 

(5.1.1) 

(8.2.3) 

(5.1.1) 

1  <floating-formula> 

< relations l-operator> 

<f loa ting- formal a> 

(5.1.2) 

(8.2.3) 
(5.1.2) 

1  <f lxed-formula> 

<relat Iona 1-ope rat or> 

<f ixed-f ormula> 

(5.1.3) 

(8.2.3) 
(5.1  .3) 

1  <character-f ormula> 
<relational-operator> 
<character-f ormula> 

(5.3) 

(8.2.3) 

(5.3) 

1  <status-formula> 

<relat Iona 1-opera tor> 
<status-formula> 

(5.4) 

(8.2.3) 

(5.4) 

1  <bl t-pr Imary> 

<equal-or-not -equal -ope rator> 
<bl t-prlmary> 

(5.2) 

(8.2,3) 

(5.2) 
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I  <pointer-f  oniiula> 

<relational-operator> 

<polnter-formu]a> 


(5.5) 

(8.2.3) 

(5.5) 


Semantics ; 

A  < rel a t lonal-expressl on>  represents  a  value  obtained  by  comparing 
two  formulas  vising  a  <rel at ional-opera tor> .  Its  type  class  Is  B  and  Its 
size  Is  one  bit. 

The  relational  operators,  =  (equal),  <>  (not  equal),  <  (less  i  .>an) , 
>  (greater  than),  <=  (less  than  or  equal),  and  >=  (greater  than  or 
equal),  carry  their  u'oal  meanings. 


Character  comparisons  will  be  made  on  the  basis  of  the  collating 
sequence  of  the  character  set  used  In  a  given  Implementail  jn. 


Status  comparisons  will  be  made  on  the  basis  of  the  representation 
cf  the  status  values. 


Pointer  comparisons  will  be  made  on  a  target-machine-dependent 
basis . 

For  bit  and  character  oi)crands,  the  shorter  will  be  implicitly 
converted  to  the  type  of  the  longer  as  described  In  Section  7.0. 

Constraints : 


Uhen  both  operands  are  <s tatus-cons t ant s> ,  at  least  one  must  be 
unambiguously  associated  with  a  single  status  type. 

«  When  the  two  operands  are  <status-formulas> ,  their  types  must  be 

‘  Identical. 

When  the  two  operands  are  <polnter-formulas> ,  their  types  must  be 
^  identical  or  one  must  be  an  untyped  pointer. 

When  both  operands  are  <fixed  formulas>,  there  must  exist  a  type  to 
which  both  operands  are  Implicitly  convertible. 


2  5.2.2  BOOLEAN  FORMULAS 


P6 
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Syntax: 

<boo]  ean-f  o  rmiil  a>  ::=  <b1  t  -  f  o  rinii  1  a>  (9.2) 

Scinant  1  cs  : 

A  <boolean-fonmi]  a>  Is  HI  t-f  orinul  a>  whose  size  ts  one  bit.  It 
bas  tlie  value  TRUE  if  the  va  j .  of  the  hit  Is  one  and  FAl.SE  otherwise. 

Const  ra 1 nt 6  : 

In  contexts  syntactically  requiring  a  <bool  an-formula> 
(<1  f-s  t  a  t  enien  t  6>  ,  <wh  1 1  e-phrases>  ,  and  1 1  rac e -e ont  ro  1  ,s> )  ,  a 

<bl  t-f  o  rinu  1  a>  cannot  be  Implicitly  convr>-ted  to  a  <bf>o  1 'an- f  o  r  i'j  1 1  ab  . 

-■  1 

5.3  CHARACTER  FORMULAS 
SyiU  ax ; 

<charact  er-forrmjla>  ::=  <char<!c- 1  er-1  i  i  eral>  (8.3.4) 

I  <cha  r.ic  t  or- va  r  1  abl  e> 

I  <namod-cha rac t  or -constant> 

I  <charact  or-f  unc l i on-cal  1> 

I  (  <charat  t  (' r-f  orinul  a>  ) 


I  <character- conversl on>  (7.0) 

(  <  f  o  I  iiuil  a>  )  (5.0) 

<oha rac t er-va r 1 ab le>  : :=  <\nriab]e>  (6.1) 

<named-charac t c I -c ons t ant >  :  ;=  <named -c ons t an t >  (6.2) 

<character-functlon-cal 1>  :  < f unc 1 1 on-ca 1 1>  •  (6.3) 

<compl  1  o- 1  Ime-charact  er-f  oimvil  a>  :  :=  <cha rac t  er- f  o  nnu  1  a> 

Soman 1 1 c  s : 


A  <character-forniula>  represents  a  value  whose  type  class  is 
character.  Its  size  is  the  number  of  bytes  comprising  its  value. 
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Constraints : 

A  <character-variable>  must  be  a  <variab]e>  whose  type  class  is 
character. 

A  <named-character-constant>  must  be  a  <nanied-constant>  whose  type 
class  Is  character. 

A  <character-funct lon-call>  must  be  a  <functlori-call>  whose  result 
value  Is  character. 

A  <compl le-t lme-character-formula>  must  be  a  <character-formu]a> 
whose  value  Is  known  at  compile  time  (see  Section  5.0). 


5.4  STATUS  FORMULAS 


Syntax ; 

<status-foniiula> 


<status-varlable> 

<named-status-constant>  : 

<status-functlon-call> 
<complle-tlme-status-formula>  : 
Semantics ; 

A  <status-fonnula>  represents 
Constraints : 

A  <status-varl able>  must  be  a 
status . 


<status-constant> 

<status-varlable> 

<named-status-constant> 

<status-functlon-call> 

(  <status-forroula>  ) 

<status-convc>rsion> 

(  <formiila>  ) 

<va  ri abl e> 

<nanied-const3nt> 

<functlon-call> 

<status-formu]a> 

a  value  whose  type  class 

<varlable>  whose  type 


(2.1 .1 .6) 


(7.0) 

(5.0) 

(6.1) 

(6.2) 

(6.3) 


Is  status. 


class  is 
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A  <named-status-constant>  must  be  a  <named-constant>  whose  type 
class  Is  status. 


A  <status-functlon-caH>  must 
value  is  status. 

be 

a  <functlon-ral 1>  whose 

resul t 

A  <compile-t lme-status-formula>  must  be  a  <statu6-formula>  whose 
value  is  known  at  compile  time  (see  Section  5.0). 

5.5  POINIER  FORMULAS 

Syntax: 

<polnt er-formula> 

:  :  = 

< pointer- 11 teral> 

(8.3.5) 

1 

<polnt er-va  rlable> 

1 

<named-polnter-constant> 

1 

<point  er-f  unct lon-cal 1> 

1 

(  <polnter-f ormula>  ) 

1 

<pointer-converslon> 

(  <formula>  ) 

(7.0) 

(5.0) 

<polnt  er-variable> 

*  •  s 

•  • 

<varlable> 

(6.1) 

<nanied-pol  nter-cons  tant> 

<nan)ed-constant> 

(6.2) 

<poir.t  er-f  unct  lon-call> 

;  := 

<functlon-call> 

(6.3) 

<compl le-t Ime- point er-fonnula> 

<polnter-f ornula> 

Semantics : 

A  <polnter-fortnula>  represents  a  value  whose  type  class  Is  pointer. 
Const  ralnts : 

A  <pointer-va rlable>  must  be  a  <varlable>  whose  type  class  is 
pointer . 

A  <named-pointer-constant>  must  be  a  <naiLed-cons tant>  whose  type 
class  is  pointer. 

A  <pointer-function-call>  must  be  a  <funct ion-call>  whose  result 
value  is  pointer. 
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A  <c  oiiipl  1  e- 1 1  me-pol  lit  cr-f  onniil a>  must  be  a  <poi  nl e r-f  ormul a>  whose 
value  Is  known  at  compile  time  (see  Section  5.0). 

5.6  TAlil.E  FORMULAS 
Synt  ax  : 


<  t  a b  1  e  -  f  o  rinu  1  a> 

<t abl e -va rl abl e> 

1  <named--t  able-cons  t  ant> 

1  (  <t abl e-1 o rmnl a>  ) 

1  < t al  1 0 -conve rs 1 on> 

(7.0) 

(  <forniula>  ) 

(5.0) 

<t  abl e  -va i 1 abl e> 

: ;  -  <va  r  i  .abl  e> 

(6.1) 

<named -1 ab 1 e-c ons 1  ant > 

<n,in.<-d-constant> 

(6.2) 

Sjem^nt  ics : 

A  <table-fonTiula>  represents  a  value  whose  type  class  is  table. 
Const  ra 1 nts  ; 

A  <table-varlable>  must  be  a  <variable>  whose  type  class  is  table. 

A  <named-table-constant>  must  be  a  <na,ned-constant>  wliose  type 
class  is  table. 
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6-0  d^a^ference^ 

6.1  VARIABLES 

<varlable> 


<natiied-varlable> 


<i tenO 


<table> 


Stable- i  t eni> 


<table-entry> 


••  ••=  <named-variable> 

1  <61t-funct  loii-varlable> 

I  <6yte-funct Jon-varlable> 

I  ^rep-funetlon  varlnblp> 

I  <funct  lon-n.iiic'> 

=  <  1 1  etn> 

I  <tai)lc> 

I  <tab]c-item> 

I  ablc-ent ry> 

I  <b]ock-l  teni> 

I  <block-tab]e> 

I  <block-tablc-l 
I  <block-tablt-enl  ry> 

:=  tein-nanie> 

I  <1 t em-do ref ertnce> 
able— naDie> 

I  ■<^table-dereference> 

-  t able— i  t erD-nnnie> 

[<subscrlpt>] 
I^table-dereference>] 

=  <table-nanie> 

<subscr 1 pt> 

I  ^fable— dereferenced 
<subscrlpt> 


(3.2) 


(2.1,1) 


(2.1.2) 


(2.1 .2.3) 


(2.1.2) 


91 


M1L-STD-1589B  (USAF) 
06  June  1980 


<bl ock-1 tem> 

*  *  * 

<ltem-naine> 

(<block-de  ref  erence> ) 

(2.1.1) 

<bl ock-t  able> 

:  :  = 

<t  able-name> 

1 <block-de  reference>] 

(2.1.2) 

<block- table-1 tem> 

<table-l tem-name> 

( <6ubscrlpt> ) 
(<block-dereference>  ] 

(2.1  .2,3) 

<block-t able-entry> 

:  :  = 

<table-name> 

<subscrl pt> 
(<block-dereference>] 

(2.1.2) 

<block-deref erence> 

:  :  = 

<dereference> 

< 1 1 em-de  ref  e  rence> 

:  ;  = 

<dereference> 

<tabl e-dereference> 

:  :  = 

<dereference> 

<dereference> 

0  <polnter-l  tem-nanie> 

1 

0  (  <polnter-f ormula>  ) 

(5.5) 

<pointer-l  teDi-nanie> 

;:  = 

<ltem-name> 

(2.1  .1) 

1 

<table-l  tem-naine> 

CM 

CM 

1 

<constant-l  tem-nanie> 

(2.1.3) 

<subscrlpt> 

:  :  = 

(  <lndex> , . . .  ) 

(5.1.1) 

< i ndex> 

:  :  = 

<  Int  ege  r-forinula> 

(5.1.1) 

1 

<status-fonDula> 

(5.4) 

<bit-funct Ion-varlable> 

:  :  = 

BIT  (  <'bit-varlable>  , 
<fblt>  ,  <nblt>  ) 

(5.2) 

(6.3.3) 

<byte-funct lon-varl  able> 

1  1  = 

BYTE  ( 

<cbarac t e r-va r iable>  , 
<fbyte>  ,  <nbyie>  ) 

(5.3) 

(6.3.4) 

<  rep-f unct ion-va  rl able> 

:  :  = 

<rep-convers ion> 

(  <nanied-va  r  iable>  ) 

(7.0) 
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Semantics : 

A  <varlable>  designates  a  data  object  whose  value  can  be  changed  by 
assignment.  A  <nained- va r t abl e>  designates  a  data  object  whose  value  can 
be  used  in  a  formula  and  changed  by  assignment.  A  <de ref e rence> 
designates  the  data  object  whoso  address  is  contained  In  the 
<polnt er-1 tem-naine>  or  <pol nter-formula>  of  the  <de ref e rence>  . 

An  <lteni>  variable  designates  either  an  object  declared  In  an  Item 
declaration  or  an  object  p(<  nted  to  by  a  typed  pointer  whose  type-name 
attribute  Is  an  Item  type.  In  the  latter  case  the  item  Is  referenced 
with  an  <1 tem-deref erence>  (l.e.,  the  pointer  is  dereferenced  to  obtain 
the  Item). 

A  <table>  variable  designates  either  an  object  declared  in  a  table 
declaration  or  an  object  pointed  to  by  a  typed  pointer  whose  type-name 
attribute  Is  a  fable  type.  In  the  latter  case  the  table  Is  referenced 
with  a  <  table-do  re  f  e  rence>  (l.e.,  the  pointer  Is  deref(?ri-nced  to  obtain 
the  table).  The  type  class  of  a  <table>  is  table. 

A  <table-ltem>  variable  designates  an  Item  component  of  a  table. 
If  the  table  Is  dimensioned,  the  subscript  indicates  from  which  entry 
the  Item  Is  to  be  obtained.  If  <t able-ltem'name>  was  declared  in  a 
<table-type-declaratlon>  (rather  than  a  <lable - 1 t em-dec larat 1 on>)  the 
<table-deref erence>  references  the  particular  table  from  which  the  Item 
Is  to  be--obtalned. 

A  <t abl e-ent ry>  variable  designates  an  entry  in  a  dimensioned 
table.  The  table  Is  referenced  either  with  a  <tahlc-name>  or  with  a 
<table-dereferpnce>. 

The  type  class  of  a  <rable-ent ry>  Is  table  for  entries  declared 
with  an  <ord 1  nary- 1 able-body> ,  <spec 1 f 1 od- 1 abl e-body> ,  or 
< t able-type-name> ,  and  otherwise  is  the  type  specified  by  the  underlying 
< 1 1 em-t y pe-de sc r 1 pt 1 on>  .  (Note  that  <t abl e- on t r y>  is  sy n i ar t i ca 1 ly  a 
subscripted  <tablo-name>  or  < t able-de ref e renc p> . ) 

If  the  type  class  of  a  particular  <table-ent ry>  is  not  table,  any 
operation  or  Intrinsic  function  except  hOC ,  NWDSEN,  tnd  KEP  applied  to 
that  entry  Is  interpreted  as  applying  to  the  Item  whose  type  class  and 
attributes  are  given  bj  (he  miuerlying  <  i  t  em- 1  y  pe~de«;c  i  i  p  t  1  on>  .  LOG, 
NWDSEN,  and  REP  are  interpreted  as  applying  to  tlie  entire  physical  space 
occupied  by  the  object,  including  filler  bits  preceding  or  following  the 
1  tern. 

A  <block.-l  tem>  variable  designates  an  item  component  of  a  block. 
If  the  <item-name>  was  declared  in  a  <bl ock-l ype-dcc la  rat ion> ,  the 
<b lock-de re f e rence>  references  the  particular  block  from  which  the  item 
is  to  be  obtained. 
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A  <block-table>  variable  designates  a  table  component  of  a  block. 
If  the  <table-nanie>  was  declared  In  a  <block-type-declaratlon> ,  the 
<block-dereference>  references  the  particular  block  from  which  the  table 
is  to  be  obtained. 

A  <block-table-l tem>  variable  designates  an  Item  componer.t  of  a 
table  which  Is  Itself  a  component  of  a  block.  If  the  table  Is 
dimensioned,  the  subscript  Indicates  from  which  entry  the  Item  Is  to  be 
obtained.  If  the  <table-ltem-name>  was  declared  In  a  <block-type- 
declaration> ,  the  <block-dereference>  references  the  particular  block 
from  which  the  item  Is  to  be  obtained.  (Note  that  If  the 
<table-l tem~name>  was  declared  In  a  <table-type-decl arat lon> ,  It  cannot 
be  obtained  as  a  <block-table-ltem>  variable  but  must  be  obtained  as  a 
<table-item>  variable  with  a  <table-deref erence> . ) 

A  <block- table-entry>  variable  designates  an  entry  in  a  dimensioned 
table  which  Is  contained  In  a  block.  If  the  <table-narae>  was  declared 
In  a  <block-type-declaratlon>,  the  <block-dereference>  references  the 
particular  block  from  which  the  table  entry  Is  to  be  obtained. 

A  <bl t-f unctlon-variable>  is  the  use  of  the  BIT  function  in  an 
assignment  context  (l.e.,  the  target  of  an  assignment  statement  or  an 
actual  output  parameter)  to  designate  that  a  specified  substring  of  the 
<bit-variable>  Is  to  be  used  as  a  variable.  <Fblt>  indicates  the 
starting  bit  and  <nblt>  Indicates  the  size  of  the  substring.  Bits  are 
numbered  from  the  left  beginning  with  zero. 

A  <by t e-f unct lon-va rl abl e>  Is  the  use  of  the  BYTE  function  In  an 
assignment  context  (l.e.,  a  target  of  an  assignment  statement  or  an 
actual  output  parameter)  to  designate  that  a  specified  substring  of  the 
<cha rac t er-va rl abl e>  Is  to  be  used  as  a  variable.  <Fbyte>  indicates  the 
starting  character  and  <nbyte>  indicates  the  size  of  the  substring. 
Characters  are  numbered  from  the  left  beglniiing  with  zero. 

A  <rep-f unct Ion-varlable>  Is  the  use  of  the  <rep-conversion>  In  an 
assignment  context  (l.e.,  the  target  of  an  assignment  statement  or  an 
actual  output  parameter)  to  designate  that  the  <named'va riable>  Is  to  be 
treated  as  a  bit  string  variable  whose  size  Is  the  number  of  bits  of 
storage  actually  occupied  by  the  <named-variable> . 

Const  r^l  nt^ : 

A  <subscrlpt>  must  be  present  In  a  <table-item>  or 
<block-table-item>  If  the  type  of  the  table  is  dimensioned. 

A  <subscrlpt>  In  a  <table-ltem>,  <table-ent ry> ,  <block-table-Item>, 
or  <block-table-entry>  must  contain  the  same  number  of  <lndlces>  as 
there  are  <dlmenslons>  In  the  <dlmension-l 1 st>  of  the  declaration  of  the 
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table's  type.  Furthermore,  the  type  of  each  <lndex>  must  be  the  same  as 
the  type  of  the  corresponding  <dlmenslon>  and  the  value  of  each  Index 
must  be  within  the  bounds  specified  for  that  dimension.  If  the 
designated  table  Is  a  formal  parameter  and  the  <dlinenslons>  were 
specified  as  *,  the  Indices  must  be  <lnteger-formula6>  (even  If  bounds 
of  an  actual  parameter  on  a  particular  Invocation  are  of  status  type), 
and  the  value  of  each  Index  must  be  In  the  range  0  through  NN-1,  where 
NN  Is  the  numbeij'  of  elements  In  that  dimension  of  the  actual  parameter. 

If  the  <table-l tem-name>  in  a  <table-ltem>  was  declared  in  a 
<table-type-declaratlon>,  the  <table-ltem>  must  contain  a  <tab]e- 
dereference>  whose  pointer  Is  of  the  appropriate  type. 

If  the  <ltem-name>  In  a  <block-Item>  was  declared  In  a 
<block-type-declaratIon>,  the  <block-ltem>  must  contain  a  <block- 
dereference>  whose  pointer  Is  of  the  appropriate  type. 

A  reference  to  a  <table-ltem>  must  not  access  storage  outside  the 
bounds  of  the  table  containing  that  <table-l tem> . 

If  the  <table-naroe>  In  a  <block-table>  or  <block- t abl e-ent ry>  was 
declared  In  a  <block-type-declaratlon>,  the  <bl ock-t abl e>  or 
<block-table-ent ry>  must  contain  a  <block-dereference>  whose  pointer  is 
of  the  appropriate  type. 

If  the  <table-l tem-name>  in  a  <block-table-Item>  was  declared  in  a 
<block-typc-dec la ra t 1 on> ,  the  <block-table-l tem>  must  contain  a 
<block-dereference>  whose  pointer  is  of  the  appropriate  type. 

<Fbit>  and  <nblt>  must  not  designate  a  substring  beyond  the  bounds 
of  the  <bi t-va riable> .  <Nblt>  must  be  greater  than  zero. 

<Fbyte>  and  <nbyte>  must  not  designate  a  substring  beyond  the 
bounds  of  the  <character-varlable> .  <Nbyte>  must  be  greater  than  zero. 

A  <f unc t ion-name>  can  be  used  as  a  <varlable>  only  within  the  body 
of  a  function  having  that  <functIon-name>,  and  then  only  as  the 
left-hand  side  of  an  assignment  statement.  The  other  valid  uses  of 
<f unct ion-name>  are  described  In  Section  3.2. 

A  p<  Inter  to  an  und 1  mens loned  parallel  or  tight  table  type  cannot 
he  used  in  a  <de re f e renc e> . 

The  value  of  a  pointer  used  In  a  <deref erence>  must  be  In  the 
implementation-defined  set  of  valid  values  for  pointers  of  Its  type.  A 
pointer  whose  value  Is  NULL  cannot  be  dereferenced. 
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6.2  NAMED  CONSTANTS 
Syntax; 


<named-c  onstant> 

:;=  <constant-i tera-narae> 

(2.1.3) 

1  <constant-tahle-name> 

(2.1.3) 

1  <cons t an t-t able-1 tom-name> 
l<si;SscrIpt>] 

(6.1) 

1  <cons t ant-t abl e-name> 
<subsc  rl pt> 

(2.1.3) 

(6.1) 

1  <cont rol-1 et t er> 

(4.2) 

<constant-table-I t em-name> 

: <tab] e-i t em-name> 

(2,1  .2,3) 

Seman  1 1 cs ; 

A  <named~constanC>  designates  a  constant  data  object  whose  value 
can  be  used  In  a  formula  but  cannot  be  changed. 

A  <constant-i tom-narae>  designates  an  object  declared  In  a  constant 
Item  declaration. 

A  <cons tant-table-name>  designates  an  object  declared  In  a  constant 
table  declaration. 

A  <constant-table-I tem-nanie>  designates  an  Item  component  of  a 
constant  table.  If  the  table  Is  dimensioned,  the  <subscript>  indicates 
from  which  entry  the  Item  is  to  be  obtained. 

A  <cons t ant-t abl e-name>  followed  by  a  <subscript>  designates  an 
entry  in  a  dimensioned  constant  table. 

A  <control-letter>  designates  an  object  created  in  a  <for-clause> 
whose  <control-I  teni>  is  a  single  letter. 

Constj-aJjjt^: 

A  <subscript>  must  follow  a  <constant-t able-1 tem-narae>  if  the  table 
Is  dimensioned, 

A  <subscrlpt>  following  a  <constant-table-I tem-name>  or  <constant- 
table-naroe>  must  contain  the  same  number  of  <lndlces>  as  there  are 
<dImenslons>  in  tne  <dimonsIon-llst>  in  the  declaration  of  the  table. 
Furthermore,  the  type  of  each  <Index>  must  be  the  same  as  the  type  of 
the  corresponding  <dimenslon>  and  the  value  of  each  <index>  must  be 
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within  the  bounds  specified  for  that  <dln)enslon> . 

Constant  tables  and  Items  selected  from  constant  tables  via 
subscripts  cannot  be  used  as  coinplle-tlme  values. 

A  <control-letter>  may  be  referenced  only  within  the 
<controlled-s tatement>  of  a  <loop-statement>  whose  <for-clause>  created 
that  <control-constant>. 


6.3  FUNCTION  CALLS 


<functIon-call>  ::=  •Cuser-def ined-function-call> 

I  <lntrlnslc-f unct  1  on-cal  1> 

I  <machlne-specl f ic-function-call> 

<user-deflned-functlon-call>: ;=  <functlon'nanie>  I 

(<actual-paratneter-l  J  st>  I  ( 


< i nt r i ns ic-f unct i on-cal  1> 


;  :=  <loc-funct ion> 

(  <next-functlon> 


<bl t-f unct ion> 

<byte-funct 1 on> 
<shift-function> 

<abs-f  unct 1 on> 

<sign-f unct ion> 

<slze-f unct ion> 

<bounds-f unct 1 on> 
<nwdsen-f  unc  1 1 on> 
<status-inverse-f unctlon> 


.3.10) 

.3.11) 


<niachlne-specif  Ic-f  unct  lon- 

call> 


<f  unct  lon-nanie> 

l<actual-parameter-list> ) 
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Semant Ics : 

Execution  of  a  <functlon-call>  causes  invocation  of  a  function. 
Any  actvial  parameters  are  bound  to  the  corresponding  formal  parameters 
as  described  In  Section  3.3. 

A  <user-def lned-functlon-call>  causes  invocation  of  a  function 
defined  in  a  <f unct 1 on-def Ini t lon> .  The  type  of  the  value  returned  by 
the  function  is  the  type  specified  by  the  <item-type-descrlptlon>  In  the 
<functlon-headlng>  of  the  <f unct lon-def Inl t 1 on> . 

An  <1 nt r 1  ns  1 c-f unc t lon-cal 1>  causes  Invocation  of  a  language- 
defined  function.  A  description  of  the  language-defined  functions  Is 
contained  In  the  following  sections.  The  type  cf  the  value  returned  by 
each  function  Is  described  In  the  corresponding  section. 

A  <machl ne-specl f Ic-f unc t 1 on-cal 1>  causes  Invocation  of  a 
machine-specific  function  (see  Section  3.5). 

Con  s  t  r  a  1  n  t_s  : 

Actual  parameters  In  the  <f unct 1 on-cal 1>  must  match  the  formal 
parameters  of  the  called  function  In  number,  type,  and  parameter  list 
position  according  to  the  rules  given  In  Section  3.3. 

6.3.1  LOC  FUNCTION 
^^n^^x : 

<loc-f unct ion>  ::=  LOC  (  <loc-arguraent>  ) 

<1 oc-a rgument>  ::=  <naroed-variable> 

I  <block-name> 

(  <statement-name> 

1  <procedore-name> 

I  <functlon-name> 

I  <block-deref erence> 

Semantics; 

The  LOC  function  can  be  applied  to  the  <loc-a rgument>  to  obtain 
the  machine  address  of  the  word  In  which  the  <1 oc-argument>  is  stored. 
If  the  <loc-argument>  Is  a  <named-var 1 able>  or  <block-name>  that  was 


(6.1) 

(2.1.4) 

(4.0) 

(3.1) 

(3.2) 
(6.1) 
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declared  with  a  <type-name>  TT,  the  type  of  the  value  returned  by  the 
LOG  function  is  P  TT  (l.e.,  a  typed  pointer).  Otherwise,  the  type  of 
the  value  returned  by  the  LOG  function  Is  P  (l.e.,  an  untyped  pointer). 

If  the  <loc-a  rgiinient>  Is  a  <statonient-name> ,  <procedure-nanie> ,  or 
<f  unct  1  on-name>  the  <loc-f  unct  ionl>  yields  an  untyjied  pointer  whose  value 
Is  the  machine  address  used  to  access  the  designated  statement  or 
subrout  1 ne  . 

^nstraints : 

The  LOG  of  a  subroutine  whose  name  appears  in  an 
<1 nl 1 ne-dec la r a 1 1 on>  ,  or  of  a  <statement-name>  whose  definition  appears 
in  such  a  subroutine.  Is  Implementation-defined. 

Note : 


The  LOG  function  cannot  be  applied  to  an  Intrinsic  function. 


6.3.2  NEXT  FUNGTION 


Synt  ajt : 


<next-funct ion> 


<next-a  rgument> 


<lncrement-amounr> 
Semant 1 cs : 


::=  NEXT  ( 

<next-a rgument>  , 

<lncrement-amount>  ) 

;:=  <polnter-formula>  (5.5) 

I  <status-formula>  (5.9) 

::=  <lnteger-formula>  (5.1.1) 


If  the  <next-arguraent>  Is  a  <pol nter-formula> ,  the  value  returned 
by  the  NEiXT  function  is  the  arithmetic  sum  of  the  representation  of  the 
<point er-f ormula>  plus  the  <lncrement-amount>  *  LOCSINWORT  (l.e.,  the 
<pointer-formula>  Is  treated  as  an  Integer).  The  type  of  the  value 
returned  Is  a  pointer  of  the  same  type  as  the  <next-a rgument> . 


If  the  <next-a rgument>  Is  a  <status-f ormula>  and  the  value  of  the 
<I ncrement-amount>  Is  N,  the  value  returned  by  the  NEXT  function  is  the 
Nth  successor  (or  predecessor  if  N  is  negative)  of  the  value  of  the 
<status-formula>  In  this  <status-l lst>.  The  type  of  the  value  is  the 
same  as  the  type  of  the  <next-argument> . 
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Constraints; 

The  <next-argunient>  cannot  be  a  <status-constant>  that  belongs  to 
more  than  one  status  type  (unless  explicitly  disambiguated  with  a 
<statu6-converBlon>) ,  nor  can  It  be  the  <pol nter-1 1 teral>  NULL. 

The  type  of  the  <status-formula>  must  be  a  status  type  with  a 
default  representation. 

Wlien  the  <next-argument>  is  a  <status-f  ormula> ,  the 
<lncrement-amount>  must  not  cause  the  NKXT  function  to  return  a  value 
out  of  range  of  the  type  of  the  <next-argument> . 

The  value  of  the  <pol nter-formiila>  and  the  value  of  the  pointer 
result  must  be  in  the  Implementation-defined  set  of  valid  values  for 
pointers  of  its  type. 

Note : 


The  value  of  the  <next-argument>  may  be  negative. 


6.3.3  BIT  FUNCTION 


Syntax; 


<blt-functlon> 

; ;=  BIT  (  <bl t-f ormula>  , 
<fbit>  ,  <nbit>  ) 

(5.2) 

<fblt> 

:  :=  <Integer-fonnula> 

(5.1.1) 

<nbi t> 

:  :=  <integer-formula> 

(3.1  .1) 

Semantics ; 

The  BIT  function  selects  a  designated  substring  from  the 
<bi t-f ormula> .  <Fblt>  indicates  the  starting  bit  and  <nbit>  indicates 
the  size  of  the  substring.  Bits  are  numbered  from  the  left  beginning 
with  zero.  The  type  of  the  value  returned  is  a  bit  string  of  the  same 
size  as  the  <bi t-f ormula> .  The  designated  substring  is  right  justified 
in  the  result  and  padded  on  the  left  with  zero  bits  as  necessary  to  fill 
the  size. 

Const  ra i n  t  s ; 

<Fblt>  and  <nblt>  must  not  designate  a  substring  beyond  the  bounds 
of  the  <bi t-formu]a> .  <Nblt>  must  be  greater  than  zero. 
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6.3.4  BYTE  FUNCTION 
Synt^jc: 

<byte-f  unct ion> 

<f byte> 

<nbyt  e> 

Semantic^: 

The  BYTE  function  selects  a  designated  svibstrlng  from  the 
<charact er-forniula> .  <Fbyte>  indicates  the  starting  character  and 
<nbyte>  Indicates  the  size  of  the  substring.  Characters  are  numbered 
from  the  left  beginning  with  zero.  The  type  of  the  value  returned  is  a 
character  string  of  the  same  size  as  the  <cha ract er-formula> .  The 
designated  substring  Is  left  justified  In  the  result,  and  padded  on  the 
right  with  blanks  as  necessary  to  fill  the  size. 

Const  ralnts : 

<Fbyte>  and  <nbyte>  must  not  designate  a  substring  beyond  the 
bounds  of  the  <character-f onnula> .  <Nbyte>  must  be  greater  than  zero. 

6.3.5  SHIFT  FUNCTIONS 
Syntax; 

<shl f t-f unct lon>  : <shi f t-d I rec t Ion> 

(  <bi t“f ormul a>  , 

<shif t-count>  )  (5.2) 

<shlf t-di rectlon>  :  :=  SHIFTL 

I  SHIFTR 

<shlf t-count>  :  ;=  <i nteger-f ormul a>  (5.1.1) 

Semant i c^ ; 

The  SHIFTL  function  performs  a  logical  left  shift  of  the 
<blt-foniiula>  by  the  number  of  positions  Indicated  by  <shif  t-count> . 
The  SHIFTR  function  performs  a  logical  right  shift  of  the  <bl t-formula> 
by  the  number  of  positions  Indicated  by  <shl ' t-c ount> .  In  both  cases, 
vacated  bits  are  filled  with  zeros  and  bits  shifted  out  are  lost.  If 
the  <shlf t-count>  Is  greater  than  or  <  ual  to  the  size  of  the 


BYTE  (  <character-formula>  , 
<fbyte>  ,  <nbyte>  ) 

(5.3) 

<1 nt egc  r-f  ormul a> 

(5.1.1) 

< 1 nt  ege r-f  ormul a> 

(5.1.1) 
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<bl  t-formu'’a> ,  the  result  Is  a  bit  string  with  all  zero  bits.  The  type 
of  the  value  returned  by  a  <shlf t-functlon>  is  the  same  as  the  type  of 
the  <bl  t-for77iula> . 

Const  ral n  t  s : 

The  value  of  <shlf t-count>  must  be  non-negative  and  less  than  or 
equal  to  MAXHITS. 

6.3.6  ABS  FUNCTION 


Syntajc: 


<abs-f unct lon>  ABS  (  <numerlc-forraula>  )  (5.1) 
Semantics : 

The  ABS  function  produces  a  value  that  is  the  absolute  value  of  the 
<numerlc-f  ormula> ,  The  result  is  equivalent  to  -  <Tiumerlc-fon7iula>  If 
<numeric~formu]a>  Is  negative  and  equivalent  to  +  <nuineric-formu]a> 
otherwise . 


6.3.7  SIGN  FUNCTION 
Syntax : 

<s  ign-f  unct lon> 

S^ant  Ic  s : 

The  SON  function  returns  a  value  according  to  the  following  rules: 


::=  SGN  (  <numeric-formula>  )  (5.1) 


Formula 

Value 

>  0 

+  1 

=  0 

0 

<  0 

-1 

The  type  of  the  value  is  S  1 
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6.3.8  SIZE  FUNCTIONS 
Syntax; 

<6lze-f unct lon>  <slze-type> 

(  <slze-argument>  ) 

<slze-type>  : BITSIZE 

I  BYTESIZE 
I  WORDSIZE 

<slze-argument>  ::=  <formula>  (5.0) 

I  <block-nanie>  (2.1.4) 

I  <type-naine>  (2. 1.1. 7) 

Semantics : 

The  BITSIZE,  BYTESIZE  and  WORDSIZE  functions  return  the  logical 
size  of  the  <size-arguraent>  in  bits,  bytes,  and  words  respectively.  The 
type  of  the  value  -returned  is  S  MAXINTSIZE.  The  logical  BITSIZE  of  each 
data  type  in  the  language  will  be  described  below.  The  logical  BYTESIZE 
Is  equal  to  BITSIZE/BITSINBYTE  if  BITSIZE  MOD  BITSINBYTE  =  0  and 
BITSIZE/BlTSINBYTE+1  otherwise.  Similarly,  the  logical  WORDSIZE  is 

equal  to  BITSIZE/BITSINWORD  if  BITSIZE  MOD  BITSINWORD  =  0  and 

BITSIZE/BITSlNWORm-1  otherwise. 

Bit ;  The  BITSIZE  of  an  object  of  type  B  NN  Is  NN 

Integer:  The  BITSIZE  of  an  object  of  type  U  NN  is  NN  and  S  NN 

is  NN+1 

Fixed:  The  BITSIZE  of  an  object  of  type  A  MM,  NN  is 

MM+NNfl 

Float ;  The  BITSIZE  of  a  float  object  is  the  number  of  bits 

of  storage  the  object  actually  occupies. 

Character :The  BITSIZE  of  an  object  of  type  C  NN  is 
NN"*BrTSINBYTE. 

Pointer :  The  BITSIZE  of  a  pointer  object  is  BITSINPOINTER. 

Status;  The  BITSIZE  of  a  status  object  is  the  <status-slze> . 
If  <status-slze>  was  specified,  the  BITSIZE  is  specified  in 
the  object's  <status-lteni-descrlptlon> .  If  no  <status-slze> 
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was  specified,  the  BITSIZE  Is  minimum  number  of  bits  of 
storage  needed  to  represent  objects  of  that  type. 

Table :  The  BITSIZE  of  a  table  or  table  entry  that  Is  not 

tightly  structured  Is  the  number  of  bits  from  the  leftmost  bit 
of  the  first  word  occupied  by  the  table  or  table  entry  to  the 
rightmost  bit  of  the  last  word  occupied  by  the  table  or  table 
entry.  The  BITSIZE  of  a  tightly  structured  table  entry  Is 
<blts-per-entry>.  The  BITSIZE  of  a  tightly  structured  table 
Is  the  number  of  bits  from  the  leftmost  bit  of  the  first  word 
occupied  by  the  table  to  the  rightmost  bit  of  the  last  entry, 
where  the  last  entry  occupies  <bits-per-entry>  bits.  Note: 
the  BITSIZE  of  a  <table-entry>  whose  type  class  Is  not  table 
Is  the  BITSIZE  of  the  item  specified  by  the  underlying 
<I tem-type-descrIptlon> . 

Block;  The  BITSIZE  of  a  block  is  NN  *  BITSINWORD,  where  NN 
Is  the  number  of  words  the  block  occupies. 

Constraints ; 

A  BITSIZE  function  must  not  be  applied  to  a  table  whose  size  In 
words  exceeds  MAXINT(MAX1NTSIZE)/BITS1NW0RD. 

A  BYTESIZE  function  must  not  be  applied  to  a  table  whose  size  In 
words  exceeds  MAXINT(MAXINTSIZE)/BYTESINWORD. 


6.3.9  BOUNDS  FUNCTIONS 


Syntax ; 

<bounds-f unct lon> 

::=  <whIch-bound> 

(  <table-name>  , 

<dimens i on-iuimbe r>  ) 

(2.1.2) 

<whIch-bound> 

: ;=  LBOUND 

1  UBOUND 

<dimension-number> 

;:=  <compile-time-lnt  eger-forraula> 

(5.1.1) 

Semantics : 

The  LBOUND  function  returns  the  lower  bound  of  the  specified 
dimension  of  the  designated  table.  The  UBOUND  function  returns  the 
upper  bound  of  the  specified  dimension  of  the  designated  table.  A 
<dimensIon-nuraber>  of  zero  refers  to  the  leftmost  <dlmension>  in  that 
table's  <d imensl on-1 1 s t> ;  a  <dlmenslon-number>  of  one  designates  the 
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next-to-lef traost  <dliiienslon>  In  the  list,  etc.  The  type  of  the  returned 
value  will  either  be  an  integer  type  or  a  status  type  depending  on  the 
declaration  of  the  designated  table.  If  the  table  Is  a  formal  parameter 
with  a  *  dimension,  the  type  will  always  be  Integer,  LBOUND  will  always 
return  zero,  and  UBOUND  will  return  NN-1 ,  where  NN  Is  the  number  of 
elements  In  that  dimension  of  the  actual  parameter. 

Constraints ; 

The  <dlmension-number>  must  be  greater  than  or  equal  to  0  and  less 
than  the  number  of  dimensions  In  the  designated  table. 


6.3.10  NWDSEN  FUNCTION 
Syntax; 

<nwdsen-f  unc t lon> 
<nwdsen-a  rgument> 

Semantics : 


: :=  NWDSEN  (  <nwdsen-a rgument>  ) 

::=  <table-name>  (2.1.2) 

I  <table-type-name>  (2.2) 


The  NWDSEN  function  returns  the  number  of  words  of  storage 
allocated  to  each  entry  in  the  named  table  or  table  type.  The  return 
type  is  S  with  default  size. 


6.3.11  STATUS  INVERSE  FUNCTIONS 
Syntax ; 

<status-lnverse-functIon> 


FIRST  ( 

<status-lnverse-argument>  ) 


<s  tat US-1 nverse-argument> 


Semantics: 


I  LAST  ( 

<status-lnverse-argument>  ) 

=•  <status-fonnula>  (5.4) 

I  <status-ty pe-name>  (2. 1.1. 6) 


The  FIRST  function  gives  the  value  of  the  lowest-valued 
<status-constant>  In  the  <s t atus-1 1 st>  associated  with  the 
<status-inverse-argument>.  The  LAST  function  gives  the  value  of  the 
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highest-valued  <6tatus-constant>  In  the  <status-l 1 st>  associated  with 
the  <6tatu6-lnverse-argument> . 

The  return  value  has  the  type  indicated  by  the 
<s  tatus-lnve  rse-argunient> . 


f  , 
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7.0  TYPE  MATCHING  AND  TYPE  CONVERSIONS 


Syntax : 


<blt-converslon> 


<blt-type-converslon> 


<lnt ege  r-conve  rs lon> 


:  :=  <bl t-t ype-convers 1 on> 

I  <rep-converslon> 

::=»  (*  <bit-iype-descrlptlon>  *) 

1  <bi  t-type-naiiie> 


=  (*  <1 nteger-t ype-desc r 1 pt lon>  *)  (2.1, 

I  <lnteger-type  name>  (2.1, 


<f loa t 1 ng-conve rs ion>  ::=  (*  <f loat Ing-type-descrl ptlon>  *)  (2.1 

I  <f loatl ng-type-name>  (2.1 


<f i xed-c  onve  rs loa> 


::=  (*  lxed-type-dcscrlptlon>  *)  (2.1 

I  <f  ixed-type-nan)e>  (2.1 


<character-convers  Ion>  :  (*  <charac ter- 1 y pe-descrl pt 1 on>  *)(2.1 

I  <cba racter-ty pe-name>  (2.1 


<status-converslon>  ;  (*  <status-t ype-nanie>  *)  (2.1 

I  <status-t ype-name>  (2.1 

<polnter-conversion>  ::=  (*  <polnter-type-descriptlon>  *)  (2.1 

I  <polnter-type-naiDe>  (2.1 
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(*  <table-type-name>  *)  (2.1.2) 

<tabl e-type-name>  (2.1.2) 

REP 

Semantics : 


<table-converslon> 


<rep-converslon> 


In  Section  2.1,  the  definition  of  type  was  given.  In  some  cases. 
Implicit  conversions  will  be  performed  to  achieve  type  equivalence.  In 
this  section,  for  each  type  class,  rules  will  be  given  regarding  when 
two  types  are  the  same,  when  an  object  of  one  type  will  be  Implicitly 
converted  to  another  type,  and  when  and  how  an  object  of  one  type  can  be 
explicitly  converted  to  another  type.  Implicit  conversions  will  never 
be  performed  on  arguments  to  explicit  conversions  or  when  the  types  of 
the  data  objects  are  required  to  match  exactly.  With  all  the 
conversions  (both  implicit  and  explicit).  If  the  value  produced  after 
conversion  Is  not  In  the  range  of  values  of  the  type  being  converted  to, 
the  conversion  Is  Illegal. 


For  purposes  of  type  equivalence,  a  user-defined  <type-name>  Is 
considered  an  abbreviation  for  its  specification. 

A  <formula>  may  be  explicitly  converted  to  another  type  by 
enclosing  it  in  parentheses  and  preceding  It  with  appropriate 
conversion.  Note  that  if  the  conversion  does  not  consist  of  a  single 
letter  or  name,  it  must  be  enclosed  In  (*  and  *). 

Omitted  attribute  specifiers  In  type  conversions  Imply  the  same 
default  values  as  for  declarations  of  those  types. 


Type  equivalence  and  conversion  rules  for  each  of  the  J73  type 

classes  are  as  follows; 

Bit  (B) 

Type  Equivalence:  Two  bit  types  are  equivalent  If  their  size 

attributes  are  equal. 

Implicit  Conversions:  A  bit  string  will  be  implicitly  converted  to  a 

bit  string  with  a  different  size  attribute, 
with  truncation  on  the  left  or  padding  with 
zeros  on  the  left.  Implicit  truncation  is  not 
permitted  when  the  syntax  requires  a 
<boolean-f ormula> . 


Explicit  Conversions:  Any  data  object  except  a  block  may  be 

explicitly  converted  to  a  bit  string  with  a 
<bIt-converslon>.  A  <blt-converslon>  may  be 
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Integer  (S  and  U) 

Type  Equivalence: 

Implicit  Conversions: 


either  a  <blt-type-converslon>  or  a 
<rep-converslon> . 

A  <blt-type-converslon>  to  a  type  B  NN  takes 
the  rightmost  NN  bits  of  the  data  object's 
representation.  If  there  are  fewer  than  NN 
bits,  the  object  will  be  padded  on  the  left 
with  zeroes.  The  default  value  for  NN  Is  1  .  A 
<blt-type-converslon>  may  be  applied  to  a  data 
object  of  any  type.  If  the  object  being 
converted  is  a  table  or  table  entry,  all 
"filler"  bits  (l.e.,  bits  that  contribute  to 
the  size  of  the  table  but  that  are  not  part  of 
the  component  objects'  sizes  as  declared)  are 
Included  In  the  string.  If  the  object  to  be 
converted  Is  of  type  class  character,  filler 
bits  between  bytes  and  unused  bytes  following 
the  end  of  the  string  are  not  Included. 

A  <rep-conversIon>  provides  a  means  of 
obtaining  the  representation  of  a  data  object. 
A  <rep-converslon>  treats  a  data  object  as  a 
bit  string  whose  size  is  the  number  of  bits 
actually  occupied  by  the  object.  This  includes 
all  filler  bits  and  the  bits  in  the  unused  (but 
allocated)  bytes  following  the  ends  of 
character  strings.  For  all  objects  whose  type 
class  is  table,  the  number  of  bits  In  the  bit 
string  Is  the  same  as  the  BITSIZE  of  the 
object.  For  all  <table-ent rles>  whose  type 
class  Is  not  table,  the  number  of  bits  in  the 
bit  string  Is  the  total  number  of  bits 
(including  filler  bits)  In  the  table  entry.  A 
<rep-converslon>  can  appear  in  the  target  of  an 
assignment  statement  (see  Section  6.1).  A 
<rep-converslon>  can  be  applied  to 
<named-variables>  only;  further,  It  cannot  be 
applied  to  tables  declared  with  *  dimensions, 
to  entries  In  parallel  tables,  or  to  tables 
whose  size  In  bits  exceeds  MAXBITS. 


Two  Integer  types  are  equivalent  If  they  are 
both  S  or  U  and  if  their  size  attributes  are 
equal . 

An  Integer  type  will  be  Implicitly  converted  to 
any  other  integer  type. 
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Explicit  Conversions; 


El  oat  1  nj_  ( 

Type  Equivalence: 

Irapliclt  Conversions: 


Explicit  Conversions; 


An  <lnteger-converslon>  Is  used  to  explicitly 
convert  a  data  object  to  an  integer  type.  The 
conversion  can  be  applied  to  objects  of  bit, 
Integer,  fixed,  float,  and  pointer  only. 

A  bit  string  will  be  treated  as  representing 
the  value  of  the  Integer  type  If  the  size  of 
the  bit  string  Is  less  than  or  equal  to  the 
BITSIZE  of  the  Integer  type.  Otherwise,  the 
conversion  Is  Illegal.  If  the  size  of  the  bit 
string  Is  less  than  the  BITSIZE  of  ‘he  Integer 
type,  the  bitstring  will  be  padded  on  the  left 
with  zeroes. 

An  Integer,  fixed,  or  floating  data  object  will 
be  converted  to  the  Integer  type,  with 
truncation  or  rounding  If  specified. 

Converting  a  pointer  to  an  Integer  type  is 
equivalent  to  first  converting  the  pointer  to 
type  B  BITSINPOINTER  and  then  converting  the 
bit  string  to  Integer. 


Two  floating  types  are  equivalent  If  their 
precision  attributes  are  equal. 

A  floating  type  will  be  Implicitly  converted  to 
a  floating  type  of  the  same  or  greater 
p’^eclsion  regardless  of  the  round-or-truncate 
attribute.  A  <real-llteral>  will  be  implicitly 
treated  as  a  <floatlng-llteral>  In  the  contexts 
specified  In  Section  8.3.1.  (Implicit  floating 
conversions  do  not  change  numeric  values 
although  they  may  cause  a  cliange  in  how  the 
value  Is  represented.) 

A  <floatlng-converslon>  Is  used  to  explicitly 
convert  a  data  object  to  a  floating  data  type. 
The  conversion  can  be  applied  to 
<real-literals>  and  to  objects  of  bit.  Integer, 
fixed,  and  float  types  only. 

A  bit  string  will  be  treated  as  representing 
the  value  of  the  floating  type  If  the  size  of 
the  bit  string  equals  the  BITSIZE  of  the 
floating  type.  Otherwise  the  conversion  Is 
1 1 1 egal . 
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Fixed  (A) 

Type  Equivalence: 

Implicit  Conversions: 


Explicit  Conversions; 
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An  Integer,  fixed,  or  floating  data  object  will 
be  converted  to  the  floating  type,  with 
t»'uncatlon  or  rounding  as  specified  In  the 
<floatlng-converslon> .  Rounding  and  truncation 
are  performed  with  respect  to  the  Implemented 
precision  of  the  type  specified  by  the 
<f loatlng-converslon> . 


Two  fixed  point  types  are  equivalent  If  their 
s'ale  attributes  are  equal  and  their  fraction 
attributes  are  equal. 

A  fixed  point  type  will  be  Implicitly  converted 
t  an  ther  fixed  point  type  If  the  scale  and 
fraction  attributes  of  the  target  type  are  both 
at  least  as  large  as  those  of  the  source  type. 
A  <real-l 1 teral>  will  be  Implicitly  treated  as 
a  <flxed-llteral>  In  the  contexts  specified  In 
Section  8.3.1.  Implicit  fixed  conversions  do 
not  change  the  numeric  value  represented  except 
when  the  Implemented  precision  of  the  result 
value  is  less  than  the  Implemented  precision  of 
the  value  being  converted  (see  Section 
2. 1.1.3);  in  this  case,  rounding  or  truncation 
occurs  with  respect  to  the  Implemented 
precision  of  the  converted  value.  This 
situation  occurs  only  when  assigning  to  a 
packed  fixed  table  item  (In  an  assignment 
statement,  loop  <cont rol-va rlabl e>  ,  table 
preset,  or  output  parameter);  the 
<round-or-truncate>  attribute  of  the  table  Item 
determines  whether  the  assigned  value  Is 
"'^unded  or  truncated. 

A  <f lxed-converslon>  Is  used  to  explicitly 
convert  a  data  object  to  a  fixed  point  data 
t;  The  conversion  can  be  applied  to 
<■.  -llteral>  and  to  objects  of  bit,  integer, 
^i/.  '  and  float  types  only. 

A  bit  string  will  be  treated  as  representing 
the  Value  of  the  specified  fixed  point  type  If 
the  size  of  the  bit  string  equals  the  BITSIZE 
of  the  fixed  point  type.  Otherwise,  the 
conversion  Is  Illegal. 
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Character 

Type  Equivalence: 

Implicit  Conversions: 

Explicit  Conversions: 


Pointer  (P) 

Type  Equivalence; 

Implicit  Conversions: 
Explicit  Conversions; 


An  integer,  fixed,  or  floating  data  object  will 
be  converted  to  the  specified  fixed  point  type, 
with  truncation  or  rounding  as  specified  in  the 
<f Ixed-convers lon> .  Rounding  and  truncation 
are  performed  with  respect  to  the  implemented 
precision  of  the  type  specified  by  the 
<f lxed-converslon> . 


Two  character  types  are  equivalent  if  their 
size  attributes  are  equal. 

A  character  string  will  be  implicitly  converted 
to  a  string  with  a  different  size  attribute, 
with  truncation  on  the  right  or  padding  with 
blanks  on  the  right. 

A  <character-conversion>  Is  used  to  explicitly 
convert  a  data  object  to  a  character  data  type. 
The  conversion  can  be  applied  to  objects  of 
type  bit  or  character  only. 

A  bit  string  will  be  treated  as  representing 
the  value  (excluding  filler  bits  between  bytes) 
of  the  character  type  if  the  size  of  the  bit 
string  equals  the  BITSIZE  of  the  character 
type.  Otherwise  the  conversion  is  Illegal. 

A  character  string  will  be  converted  to  type  C 
NN  by  taking  the  leftmost  NN  characters.  If 
there  are  fewer  than  NN  characters,  the  value 
Is  padded  on  the  right  with  blanks. 


Two  pointer  types  are  equivalent  if  they  are 
both  untyped  pointers  or  if  they  are  both  typed 
pointers  referring  to  the  same 
<type-declaration> . 

A  typed  pointer  will  be  implicitly  converted  to 
an  untyped  pointer. 

A  <polnter-conversion>  is  used  to  explicitly 
convert  a  data  object  to  a  pointer  type.  The 
conversion  can  be  applied  to  bit,  Integer,  or 
pointer  data  objects  only. 
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Status 

Type  Equivalence: 


Implicit  Conversions: 


A  bit  string  will  be  treated  as  representing 


the  value  of  the 

poi nter 

type 

if  the  size 

of 

the  bit  string 

equal s 

the 

BITSIZE  of 

the 

pointer  type. 

Otherwise  the  conversion 

i  s 

1 1  legal . 

Converting  an 

Integer 

to 

a  pointer 

1b 

equivalent  to  first  converting 

the  Integer 

to 

type  B  BITSINPOINTER  and  then  converting  the 
bit  string  to  a  pointer. 

Converting  a  pointer  to  a  different  pointer 
type  means  that  the  pointer  will  be  considered 
as  a  pointer  of  the  specified  type. 


Two  status  types  are  equivalent  if  (1)  they 
both  have  default  representation,  their  size 
attributes  are  the  same,  and  both 
<status-lists>  contain  the  same  <status- 
constants>  In  the  same  order,  or  (2)  they  both 
have  Identical  programmer-specified 
representations,  their  size  attributes  are  the 
same,  and  both  <status-l ists>  contain  the  same 
<status-constants> . 

A  status  type  will  be  Implicitly  conve-ted  to  a 
status  type  that  differs  only  in  its  size 
attribute.  Furthermore,  a  status  constant 
belonging  to  more  than  one  status  type  Is 
implicitly  disambiguated  in  the  following 
contexts:  (1)  when  it  is  the  source  value  of 
an  assignment  statement,  it  takes  the  type  of 
the  target  variable;  (2)  when  it  Is  an  actual 
parameter.  It  takes  the  type  of  the 
corresponding  formal  parameter;  (3)  when  It  is 
in  a  table  <subscript>  or 
<preset-index-specif ier> ,  it  takes  the  type  of 
the  corresponding  <dimension>  in  that  table's 
declaration;  (4)  when  It  is  a  loop 
<inltial-value>,  it  takes  the  type  of  the 
<cont rol-varlable> ;  (5)  when  It  Is  In  an 
<ltem-preset>  or  <table-preset> ,  it  takes  the 
type  of  the  item  or  table  Item  being 
initialized;  (6)  when  It  is  an  operand  of  a 
<relational-operator> ,  it  takes  the  type  of  the 
other  operand;  (7)  when  it  is  in  a 
<case-lndex-group> ,  it  takes  the  type  of  the 
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<casc-st'l ector-f oriMul a> ;  and  (8)  vdii'n  It  Is  a 
<lov.'er-hoiind>  or  <uppc- r-boiHid> ,  It  takes  the 
type  of  the  other  bound. 

r.xpliclt  Conversions:  A  <s t a t os-conve rs  1  on>  Is  used  to  explicitly 

convert  a  data  object  to  a  status  type.  The 
convorslon  can  be  applied  to  bit  or  status  data 
objects  only. 

A  bit  string  will  be  treated  as  representing 
the  representational  value  of  the  status  type 
if  the  size  of  the  bit  string  equals  the 
BITSIZE  of  the  status  type  and  the  value  of  tlie 
bit  string  is  within  the  range  of  values  of  t  !ic 
status  type.  Otherwise  the  convirsion  is 
1 1 1 egal . 

A  <status-ronversion>  nay  bo  used  to  assert  tlie 
type  of  a  status  object.  This  will  he 
required  when  a  status  constant  belongs  to  irore 
than  one  type  and  it  Is  used  in  a  iDntext  other 
than  these  enumerated  above  under  implicit 
conversions.  Except  for  status  objects  whose 
types  tllffer  only  in  their  size  attributes,  a 
status  object  cannot  be  converted  to  a 
different  status  type  without  first  converting 
it  to  a  bit  string. 

TaMe 

Type  Equivalence:  Two  tables  have  equivalent  types  if  they  are 

both  ordinary  or  both  specified,  their 
<structurc-speci  f  ler>  attribute  is  tlie  same, 
they  have  the  same  number  of  dlr.ensions,  they 
have  the  same  number  of  elements  In  each 
dimension,  they  have  the  same''  number  of  items 
in  the  same  textual  order  in  each  entry,  the 
types  (including  attributejs)  of  the  items  are 
equivalent,  the  (explicit  or  implied)  packing 
specifier  on  each  of  the  items  is  tlie  sane  (for 
ordinary  tables),  the  lOPDER  directive  Is 
either  present  in  both  tables  or  absent  in  both 
tables,  the  <words-per-enLry>  attribute  is  the 
same  (for  specified  tables),  and  the 
location-specil iers  of  the  items  are  the  same 
(for  specified  tables).  (Note  that  the  names 
of  the  items,  as  well  as  the  types  and  bounds 
of  the  dimensions,  need  not  be  the  same.)  A 
table  entry  is  considered  to  have  no 

I  H 
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dimensions.  A  table  whose  entry  contains  an 
Item-declaration  Is  not  considered  equivalent 
in  type  to  a  table  whose  entry  is  declared 
using  an  unnamed  Item  description. 

Implicit  Conversions:  No  Implicit  conversions  are  performed. 

Explicit  Conversions:  A  bit  v>r  table  data  object  may  be  explicitly 

converted  to  a  table  type  with  a  <table- 
converslon> . 

A  bit  string  will  be  treated  as  representing 
the  value  of  the  table  type  if  the  size  of  the 
bit  string  equals  the  Bl’lSlZE  of  the  table 
type.  Otherwise  the  conversion  is  Illegal. 

A  <table-conversIon>  may  be  applied  to  a  table 
object  of  that  tyjce  merely  to  assert  Its  type. 
(A  table  object  cannot  be  conveited  to  a 
different  table  type  wiiMut  first  converting 
it  to  a  bit  string ) . 
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8.0  BASIC  ELEMENTS 
8 . 1  CHARACTERS 


Syntax; 


<character> 


<letter> 


<dlglt> 


<mark> 


Semantics: 


I 

I 

I 


I 

I 

I 

I 


I 


I 

I 

I 


<1 e  1 1  er> 
<dlelt> 
<ma  rk> 


<ot 

A 

G 

M 

5 
Y 
0 

6 
+ 

( 

$ 


or-cha  rac  t  e  r> 


B 
H 
N 
T 
Z 
1 
7 

(3 

) 

blank 


C  I  D  I  E  I  F 

1  I  J  I  K  I  L 

0  1  P  I  Q  I  R 

U  I  V  I  W  I  X 

2  I  3  I  4  I  5 

8  I  9 

*  I  /  I  >  I  < 

.  I  :  I  >  I  : 

'  !  "  I  %  I  1 


The  text  of  a  J73  <conipl ete-program>  is  a  continuous  stream  of 
<character s>  •  However,  In  some  contexts,  the  end  of  an  input  record  has 
significance  (see  Section  8.2). 


Note  that  In  the  standard  character  set  for  the  language  <letters> 
are  defined  to  be  upper  case  letters  only.  <Marks>  are  used  either 
alone  or  in  conjunction  with  other  characters  as  operators,  delimiters, 
and  separators.  <0ther-characters>  are  the  remaining  implementation- 
dependent  characters,  which  are  accepted  within  <character-literals>  and 
<comments>,  and  which  may  also  be  used  as  described  below.  Each 
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implementation  must  define  these  characters,  as  well  as  the  ordering  of 
all  <character6>  In  a  collating  sequence. 

Some  of  the  standard  characters  are  not  universally  available; 
therefore,  the  following  standard  alternates  are  defined: 

Standard  Character  Al^erna^^ 

0  t  or  ? 

'  ->  or  _ 

•'  4 

!  V 

X  = 

:  % 


If  any  of  the  above  standard  characters  are  unavailable  on  a  particular 
machine,  one  of  the  recommended  alternates  for  that  character  must  be 
used.  (The  first  column  of  alternates  is  intended  for  the  CDC  standard 
63  and  64  character  sets;  the  alternates  ?  and  _  are  intended  tor  the 
Unlvac  1108.)  If  the  :  is  replaced,  the  X  must  also  be  replaced. 

An  implementation  that  has  lower  case  letters  available  in  addition 
to  uppercase  may  permit  their  use  in  programs  provided  that  within 
<names>,  <reserved-words> ,  <letters>,  <status--constants>  and  all 
<llterals>  except  <character-l iterals>  they  are  considered 
interchangeable  with  their  corresponding  uppercase  letters  (e.g.,  XX 
and  XX  denote  the  same  name);  whereas  within  <character-literals>  they 
are  considered  distinct. 

An  implementation  that  has  square  brackets  available  may  allow  [ 
to  be  used  for  (*  and  ]  to  be  used  for  *)  but  may  not  prohibit  the  use 
of  the  (*  and  *). 

Constraints  : 

If  a  left  bracket  is  substituted  for  (*,  then  a  right  bracket  must 
be  substituted  for  the  corresponding  *).  If  a  right  bracket  is 
substituted  for  *),  then  a  left  bracket  must  be  substituted  for  the 
corresponding  (*. 
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8.2  SYMBOLS 


Syntax ; 
<sytnbol> 


Semantics : 


::=  <name>  (8.2.1) 

I  <reservt'd-word>  (8.2.2) 

I  <operator>  (8.2.3) 

I  <llteral>  (8.3) 

1  <stat us -constant>  (2. 1.1. 6) 

I  <comment>  (8.4) 

I  <def inc-st ri ng>  (2.4) 

I  <def i ne -cal 1>  (2.4.1) 

I  <letter>  (8.1) 

1  <separator>  (8.2.4) 


<Characters>  are  combined  into  <symbols>  to  form  the  vocabulary  of 
the  language.  <Syrabols>  are  Indivisible  units  and  ’cannot  contain 
blanks,  except  as  noted  in  Section  8.5.  Only  <comments>, 
<def lne-strlngs> ,  define  parameters  enclosed  in  quotation  marks, 
<bi t-1 i t e ral s>  ,  and  <character-l lterals>  may  extend  across  multiple 
input  records;  all  other  symbols  are  terminated  by  the  end  of  an  input 
record . 


8.2.1  NAMES 
Syntax ; 

:  :=  <letter-or-S> 

<]etter-diglt-$-or-prlme>.  .. 

::=  <letter> 

I  $ 

<let ter-di glt-$-or-prime>  :  <letter>  (8.1) 


<n.ime> 

<letter-or-$> 


1 18 
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I  <dlglt>  (8.1) 

I  $ 

I 


Seman tics: 

<Nanies>  are  words  having  programmer-supplied  spellli.gs.  <Names> 
are  used  to  denote  entitles  In  the  <complete-program> . 

Only  the  first  31  characters  of  a  J73  <name>  are  used  to  determine 
uniqueness.  Additional  characters  are  permitted,  but  are  ignored. 

For  external  names,  an  implementation  may  further  restrict  the 
number  of  Initial  characters  that  determine  uniqueness. 

A  dollar  sign  In  a  <name>  Is  translated  to  an 
implementation-dependent  representation.  This  translation  of  the  dollar 
sign  permits  the  use  of  a  character  In  a  <name>  that  might  otherwise  be 
unrepresentable  In  the  language.  If,  for  example,  external  names  in  a 
given  system  were  prefixed  by  the  character  a  J73  implementation  on 

that  system  might  choose  to  represent  when  it  occurs  in  a  name  by 

the  representation  for  Thus,  the  name  '  $$ABC'  occuring  in  a 

source  program  would  be  translated  '..ABC'. 

8.2.2  RESERVED  WORDS 


Syntax : 


<reserved-word> 


ABORT  1 

AbS  1 

AND  1  BEGIN 

1  BIT 

BITSIZE 

1  BLOCK 

1  BY  1  BYREF 

BYRES  1 

BYTE  1 

BYTESIZE  1 

BYVAL 

CASE  1 

COMPOOL 

1  CONDITION* 

CONSTANT 

1  DEF 

1  DEFAULT  1 

DEFINE 

ELSE  1 

ENCAPSULATION*  |  END 

1  EQV 

EXIT  1 

EXPORTS* 

1  FALLTHRU 

1  FALSE 

FIRST  1 

FOR  1 

FREE*  1  GOTO 

HANDLER* 

1  IF 

1  IN*  1  INL 

INE 
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INSTANCE  1  INTERRUPT*  | 

ITEM 

LABEL 

1  LAST 

1  LBOUND  1 

LIKE 

LOC  1 

MOD  1 

NENT*  1  NEW* 

NEXT  1 

1  NOT  1 

NULL  1 

NWDSEN 

1  OR  1 

OVERLAY  1 

PARALLEL 

POS  1 

PROC  1 

PROGRAM  1 

PROTECTED* 

READONLY*  1  REC  |  REF  | 

REGISTER* 

RENT  I 

REP  1 

RETURN  1 

SGN 

SHIFTL 

1  SHIFTR  1  SIGNAL* 

START 

1  STATIC 

1  STATUS 

1  STOP 

TABLE 

1  TERM 

1  THEN  1 

TO* 

TRUE  1 

TYPE  1 

UBOUND  1 

UPDATE* 

WHILE 

)  WITH* 

1  WORDSIZE 

WRITEONLY*  I  XOR  1  ZONE* 

Semantics ; 

<Reserved-words>  have  language-defined  meanings  and  cannot  be  used 
as  <nariies>. 


Those  reserved  words  followed  by  an  *  in  the  above  list  are 
reserved  In  order  to  maintain  upward  compatibility  with  future 
extensions  to  the  language  and  currently  have  no  meaning  in  J73. 


8.2.3  OPERATORS 


Syntax ; 

<operator> 


;:=  <arithmetic-operator> 
I  <blt-operator> 

I  <relat ional-operator> 
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<arlthmet lc-operator> 


<pl us-or-minus> 

<mul t Iply-dl vlde-or-mod> 

<inult  lply-or-dlvide> 
<blt-operator> 

<loglcal-operator> 

<rel a  t Iona 1-opera  tor> 

<equa 1-or-not-equa 1-opera tor> 
<dereference-operator> 

<assl gnment -opera tor> 
Semantics ; 


I  <dereference-operator> 

I  <asslgnment-operator> 

:  :=  <plus-or-ml nus> 

1  <mul t Iply-d lvlde-or-mod> 

I  <mult lply-or-dlvlde> 

I  ** 

::=  +  I 

;  :=  *  I  /  I  MOD 

::=*!/ 

:  :=  <loglcal-operator> 

1  NOT 

::=  AND  I  OR  |  XOR  I  EQV 
:  :=  <equal-or-not-equal-operator> 
1  <1  >1  <=  I  >= 

::=  -  I  <> 

::=  0 


The  meanings  of  these  operators  are  given  in  Sections  5,  and  6. 
The  order  of  combination  of  operators  and  operands  is  determined  by 
parentheses  and  by  the  operators'  precedence .  The  operation  implied  by 
an  operator  at  one  precedence  level  is  combined  before  the  operation 
implied  by  an  operator  at  a  lower  level.  Within  a  particular 
precedence  level,  operations  are  combined  from  left  to  right  if  the 
ILEFTRIGHT  directive  is  in  effect  and  in  an  implementation-dependent 
Older  if  the  IREARRANGE  directive  is  in  effect. 

Precedence  of  operators  is  defined  by  the  syntax  of  the  language 
and  is  summarized  below: 
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6  subscripting,  function  calls 

5  ** 

A  *,  /,  MOD 

3  +.  - 

2  =.  <>,  <.  >.  <=.  >= 

1  NOT,  AND,  OR,  EQV,  XOR 

0  assignment 

8.2.4  SEPARATORS 
Syntax ; 

<separator>  :  :=  (  |  )  |  (*  I  *) 

I  :  I  ,  I  ;  I  ! 

Semantics : 


<Separators>  are  used  for  the  following  purposes  in  J73: 

(  )  Expression  grouping,  list  delimiters,  status 

constants,  position  brackets,  subscripts,  case 
labels 

(*  *)  Type  conversions 

:  Statement  name,  case  label,  and  preset  index 

terminator;  loop  control  separator;  overlay, 
dimension,  subrange,  and  parameter  separator 

,  List  separator 

;  Statement,  declaration,  and  directive  terminator 

!  Directive  indicator,  formal  define  parameter 

marker 
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8.3  LITERALS 
Syntax ; 


<11 teral> 

:  :  = 

<nomeric-ll teral> 

(8.3.1) 

1 

<blt-Hteral> 

(8.3.2) 

1 

<boolean-l 1 teral> 

(8.3.3) 

1 

<character-llteral> 

(8. 3. A) 

1 

<pointer-lIteral> 

(8.3.5) 

Semant ics : 

<Llterals>  are  data  objects  whose  value  and  type  are  Inherent  In 
the  form  of  the  <synibol>  Itself.  Their  values  are  known  at  compile 
time,  and,  like  other  complle-time  values,  cannot  be  altered  during 
execution . 

8.3.1  NUMERIC  LITERALS 

Syntax : 

<numerlc-ll teral> 

:  ;  = 

<integer-l i teral> 

1 

<f loating-1 i tcral> 

1 

<f ixed-llter3l> 

<integer-ll teral> 

:  :  = 

<number> 

<number> 

:  :  = 

<digit>. . . 

(8.1) 

\f 1 oa t ing-li teral> 

:  :  = 

<real-l i teral> 

<real-l 1 teral> 

:  :  = 

<dlglt>...  <exponent> 

(8.1) 

1 

<f ractional-form> 

( <exponent>  J 

<exponent> 

:  :  = 

E  |<slgn>)  <number> 

<6ign> 

:  ;  = 

+  1  - 

<fract lonal-form> 

;  :  = 

<dlglt>  .  . . 

(8.1) 
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I  {<dlglt>...]  .  <dlglt>...  (8.1) 

<f lxed-1 1 teral>  :  <real-literal> 

Soinant  Ics ; 

An  <lnteger-llteral>,  LL,  denotes  a  decimal  value.  Its  type  Is  S 
NN,  wViere  NN  Is  1MPL1NTS1ZE(MINS1ZE(LL) ) . 

The  type  of  a  <real-literal>  or  a  <real-l 1 teral>  preceded  by  a 
<sign>  is  determined  by  the  context  in  which  the  literal  appears, 
namely : 

.  when  the  literal  is  used  as  a  preset  value,  it  is 

implicitly  converted  to  the  type  of  the  object  being 

preset ; 

.  when  the  literal  is  used  as  an  assignment  value,  it  is 
implicitly  converted  to  the  type  of  the  target  being 

assigned  a  value; 

.  when  the  literal  is  an  operand  of  an  infix  relational  or 
numeric  operator  and  the  other  operand  is  not  a 
real-2 i teral ,  It  is  converted  to  the  type  of  the  other 
operand; 

.  when  the  literal  is  an  actual  parameter,  it  is  converted 
to  the  type  of  the  formal  parameter; 

,  when  a  literal  Is  the  <initlal-value>  of  a  loop 

<control-clause>,  it  Is  converted  to  the  type  of  the 

<control-varlable> ; 

,  when  the  literal  is  the  argument  of  an  explicit  fixed  or 
floating  conversion,  it  is  converted  to  the  specified 

type. 

If  the  type  of  an  optionally  signed  <real-l 1 teral>  is  not  determined 
contextually,  it  is  considered  to  be  a  floating  type  with  default 
precision. 

A  <real-literal>  denotes  a  decimal  value.  If  an  <exponent>  is 
present,  the  decimal  value  preceding  the  <exponent>  is  multiplied  by  10 
to  the  value  specified  in  the  <exponent>. 

For  <real-ll terals> ,  non-<exponent>  digits  in  excess  of 
MAXS7GDIGITS  will  be  treated  as  zeroes  in  computing  the  fixed  or 
floating  value  to  be  represented. 
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Contextual  determination  of  tVie  type  of  a  real-literal  will  not  be 
affected  by  the  presence  or  absence  of  the  <rearrange-directlve>. 

Constraints ; 

<Real-llterals>  may  be  implicitly  converted  to  fixed  or  floating 
values  only. 

The  value  of  an  <lnteger-llteral>  with  size  SS  must  not  exceed 
MAXINT(SS). 

The  value  of  a  <floatlng-llteral>  with  precision  PP  must  not  exceed 
MAXFLOaT(PP). 

The  value  of  a  <f ixed-1 i teral>  with  scale  SS  and  fraction  FF  must 
not  exceed  MAXFIXF.D(  SS ,  FF)  . 


Exampl 


es : 


ITEM  FF  F  24  =  -0.1; 

ITEM  RR  F,R  24  =  -0.1; 

ITEM  TT  F,T  24  =  -0.1; 

CONSTANT  ITEM  CC  F,R  24  =  2.5; 
ITEM  JJ  F,R  24  =  CC  +  .3; 

IF  RR  >  .3;  ... 


"equivalent  to  presetting 
with  (*F  24*)  (-0.1)" 

"-0.1  is  rounded  to  a  24  bit 
mant i ssa" 

"-0.1  is  truncated  toward  minus 
infinity" 

".3  is  converted  to  CC's  type" 

".3  is  rounded  to  a  24  bit  mantissa" 


Note  that  if  II  is  an  Integer  it  m,  then  II  =  2.5  is  illegal,  since  a 
<real-llteral>  cannot  be  implic'.ly  converted  to  an  integer  value. 


8.3.2  BIT  LITERALS 
Syntax ; 

<bl t-1 I teral> 
<bead-slze> 

<bead> 


:  :=  <bead-size>  B  '  <bead>... 

::=  1  I  2  I  3  I  4  I  5 

; ;=  <digit> 

I  A|B|C|D1E|F 
I  GIHIIIJIKIL 
I  MlNlOlPiqiR 
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I  S  I  T  I  U  I  V 


Seman tics : 

A  <blt-llteral>  represents  a  bit  string  value,  A  <blt-ll teral>  Is 
composed  of  a  string  of  <beads>  whose  <bead-slze>  In  bits  Is  Indicated 
In  the  specification  of  the  literal.  The  total  size  of  the 
<blt-l 1 teral>  Is  the  <bead-slze>  times  the  number  of  beads  enclosed 
within  the  primes. 

The  <beads>  of  a  <bit-llteral>  can  be  specified  as  one  to  five  bits 
In  size.  The  <diglt>  preceding  the  B  indicates  the  <bead-slze>.  Only 
those  <beads>  whose  value  will  lit  in  the  <bead-slze>  Indicated  are 
permitted.  The  digits  0-9  represent  their  actual  values;  the  letters 
A  -  V  represent  the  values  10  -  31  (see  Table  8-1). 
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Table  8-1.  Bit-Literal  Bead  Values 


1 

1 

1 

1 

Bead 

Mi  nlmum 
Bead 
Size 

1  1 

1  Binary  | 

1  Value  1 

1  1 

1 

1 

1 

1 

Bead 

Mi  t^i mum 
Bead 
Size 

1 

1  Binary 

1  Value 

1 

1 

1 

0 

1 

1  1 

1  0  1 

1 

1 

G 

5 

1 

1  10000 

1 

1 

1 

1 

1  1 

1  1  t 

1 

I 

H 

5 

1 

1  10001 

1 

1 

2 

2 

1  1 

1  10  1 

1 

1 

1 

5 

1 

1  JOOlO 

1 

1 

3 

2 

1  1 

1  11  1 

1 

I 

J 

5 

1 

1  10011 

1 

1 

9 

3 

I  1 

1  100  1 

1 

I 

K 

5 

1 

1  10100 

1 

1 

5 

3 

1  1 
t  101  1 

1 

1 

L 

5 

1 

1  10101 

1 

1 

6 

3 

1  1 

1  110  1 

1 

1 

M 

5 

1 

1  10110 

1 

1 

7 

3 

1  1 

1  111  1 

I 

1 

N 

5 

1 

1  10111 

1 

1 

8 

9 

1  1 

1  1000  1 

1 

1 

0 

5 

1 

1  11000 

1 

1 

9 

9 

1  1 

1  1001  1 

1 

1 

p 

5 

1 

I  11001 

1 

1 

A 

9 

1  1 

1  1010  1 

1 

1 

Q 

5 

1 

1  11010 

1 

1 

B 

9 

1  1011  1 

I 

1 

R 

5 

1 

1  non 

1 

1 

C 

9 

1  1 

1  1100  1 

1 

1 

S 

5 

1 

1  11100 

1 

1 

D 

9 

1  1 

1  1101  1 

1 

1 

T 

5 

1 

1  11101 

1 

1 

E 

9 

1  1 

1  1110  1 

1 

1 

U 

5 

1 

1  lino 

1 

1 

1 

F 

9 

1  1 

1  nil  1 

1  1 

1 

1 

1 

V 

5 

1 

1 11111 

1 
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8.3.3  BOOLEAN  LITERALS 


Syntax ; 

<boolean-llteral>  :  TRUE 

I  FALSE 

Semantics ; 

<Boolean-llterals>  represent  the  two  possible  truth  values.  TRUE 
Is  equivalent  to  IB'l',  and  FALSE  Is  equivalent  to  IB'O'. 

8.3.4  CHARACTER  LITERALS 


Syntax : 

<character-literal>  ::=  <charac ter> . . .  '  (8.1) 

Semantics : 


<Character-literals>  denote  strings  of  character  values. 

<Character-lIterals>  can  contain  any  <character>  (Including  blank) 
that  Is  representable  in  an  implementation,  A  prime  character  (')  is 
represented  within  a  <character-llteral>  by  two  consecutive  primes.  The 
size  of  a  <character-literal>  in  bytes  is  the  number  of  characters 
represented  within  the  containing  primes  (two  consecutive  primes 
represent  one  character).  The  encoding  of  characters  is 
implementation-dependent . 


8.3.5  POINTER  LITERAL 


Syntax ; 

<polnter-lIteral>  ::=  NULL 

Semantics ; 

Any  pointer  item,  regardless  of  its  attribute,  cati  have  the  value 
NULL,  which  indicates  that  the  item  points  to  no  object. 
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8.4  COMMENTS 
Syntax : 
<comment> 


”  (<character>. . .]  ” 


(8.1) 


X  [ <charac t er>  .  .  .  ]  X 


(8.1) 


Semantics : 


A  <cot7iment>  has  no  semantic  effect. 

A  <comment>  in  a  <def Ine-st rlng>  or  <actual-def lne-parameter>  is 
Interpreted  as  part  of  the  character  sequence  to  be  substituted  when  the 
<def Ine-cal 1>  Is  expanded. 

A  <comment>  can  appear  between  any  two  <symbols>,  subject  to  the 
constraints  below. 

Constra ints  : 

A  <comiiient>  delimited  by  a  quotation  mark  (")  is  not  permitted 
between  a  <def ine-name>  and  a  <def ine-string>  in  a  <def ine-declara t lon> , 
or  within  the  <actual-parameter-l ist>  In  a  <def i ne-cal 1> . 

A  <comment>  delimited  by  a  quotation  mark  cannot  contain  a 
quotation  mark,  and  a  <comment>  delimited  by  a  percent  character  (X) 
cannot  contain  a  percent  character. 


8.5  BLAMKS 

One  or  more  blanks  can  be  placed  between  <symbols>.  Blanks 
occurring  between  <symbols>  have  no  semantic  meaning. 

Co nstralnt  s : 

Blanks  cannot  appear  within  <symbols>  except  in  <character- 
llterals>,  <def  ine-strings>  ,  <def  Ine-cal  1  s>  ,  and  <coniments>. 

One  or  more  blanks  must  appear  between  any  two  <symbols>  If  the 
absence  of  blanks  could  cause  them  to  be  interpreted  as  a  single  legal 
<symbol>,  except  that  whether  (*  represents  one  or  two  <symbols>  Is 
contextually  determined,  e.g.,  (*  represent's  two  symbols  In  the 

following  contexts: 

TABLE  AA  (*)  . ..; 

ITEM  ...  POS  (*,  C); 


AD-AIOO  577  AERONAUTICAL  SYSTEMS  DIV  KRtOHT-PATTERSON  ARB  OH 

AFSC  STANDARDIZATION  CONFERENCE#  1553#  1SS9*  1750#  1760# 
NOV  80  E  C  OANOH*  S  E  SMITH 

UMCLASSIFTFD  ASD-TR-60-5050-V0L^2 _ 


F/6  1/3  ^ 

ADA#  N— eTC(U) 


NL 
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9.0  DIRECTIVES 
Syntax; 

<dlrectlve> 


<coiiipool-d  Irect  i  ve> 

(9.1) 

<ccpy-dlrect i ve> 

(9.2.1) 

<sklp-dlrectlve> 

(9.2.2) 

<begl n-d 1 rec  1 1 ve> 

(9.2.2) 

<end-dlrective> 

(9.2.2) 

<Iink.age-di  rective> 

(9.3) 

<trace-di rect lve> 

(9.4) 

<lnterference-di recti ve> 

(9.5) 

<reducible-d irect ive> 

(9.6) 

<nollst-direct ive> 

(9.7.1) 

<li st-di recti ve> 

(9.7.1) 

<e ject-di recti ve> 

(9.7.1) 

<listinv-directive> 

(9.7.2) 

<listexp-directive> 

(9.7.2) 

<llstboth-di rective> 

(9.7.2) 

<base-d i r ec  t i ve> 

(9.8) 

<isbase-di rective> 

(9.8) 

<drop-direct ive> 

(9.8) 

<lef tright-d irect ive> 

(9.9) 

<rearrange-directive> 

(9.9) 

<lni tiali ze-d irect lve> 

(9.10) 

<order-direct ive> 

(9.11) 

130 

184 


MIL-STD-1589B  (USAF) 
06  June  1980 


Semantics: 


<Directlves>  are  used  to  provide  supplemental  Information  to  a 
compiler  about  the  <complete-program> ,  and  to  provide  compiler  control. 

Each  Implementation  can  specify  <dlrectlves>  In  addition  to  those 
described  here,  but  each  must  conform  to  the  general  form  for  a 
<dlrective>.  <Dlrectlves>  begin  with  an  exclamation  point  and  terminate 
with  a  semicolon,  and  the  word  following  the  exclamation  point  must  not 
duplicate  that  of  any  language-defined  directive. 


9.1  COMPOOL  DIRECTIVES 


Syntax : 

<compool-dlrect lve> 
<compool-dlrectlve-l ist> 


<compoo 1-dec la red-name> 

<compool-f lle-name> 
Semantics : 

A  <compool-dlrective> 
module . 


:=  ! COMPOOL 

[<compool-directive-llst>J  ; 

:=  [<compool-flle-name>] 

<cotnpool-declared-name>,  . . . 

1  (  (<compool-f 1 le-name> )  ) 

:=  <natDe>  (8.2.1) 

I  (  <name>  )  (8.2.1) 

:=  <character-literal>  (8. 3. A) 

is  used  to  access  definitions  In  a  compool 


A  <compool-f lle-name>  Is  an  implementation-dependent  file  name  that 
specifies  the  desired  compool.  If  it  Is  omitted,  an  implicit  unnamed 
compool  Is  assumed,  A  <compool-f lle-name>  enclosed  In  parentheses 
Implies  that  all  <names>  in  the  compool  are  to  be  made  available.  (This 
does  not  include  <naraes>  used  in  the  compool  that  were  obtained  from 
other  compools.) 

If  the  <compool-dl rect ive>  contains  a  list  of  <compool-declared- 
names>,  only  those  names  (except  as  noted  below)  will  be  made  available. 

If  a  <compool-declared-name>  Is  the  name  of  an  Item,  table,  or 
block  declared  with  a  <type-narae>,  that  <type-name>  Is  also  made 
available  If  It  Is  declared  In  that  compool.  (For  pointer  Items,  this 
Includes  the  name  of  the  point ed-to-type) .  If  a 
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<coinpool-declared-nanie>  Is  a  <table-ltem-name> ,  the  name  of  the  table  In 
which  it  is  contained  Is  also  made  available.  If  a  table  name  Is  made 
available,  any  <status-llsts>  and  <6tatus-type-naine £>  associated  with 
Its  <dlmenslons>  are  also  made  available,  provided  they  are  declared  In 
the  designated  compool. 

If  a  <compool-declared-name>  Is  the  name  of  a  table  or  block  and  Is 
parenthesized,  all  names  declared  In  the  table  or  block  will  be  made 
available,  as  well  as  all  type  names  referenced  In  the  table  or  block, 
provided  they  are  declared  In  the  designated  compool.  If  a 
<compool-declared-name>  is  a  <table-type-narae>  or  <block-type-name> ,  the 
names  of  these  components  will  be  made  available  whether  or  not  the  name 
is  parenthesized. 

If  a  status  item  name  Is  made  available,  Its  associated 
<status-llst>  and  <status-type-name>  (if  any)  will  also  be  made 
available.  If  they  were  declared  in  the  designated  compool. 

If  a  <compool-declared-name>  Is  the  name  of  a  subroutine,  any 
<type-names>  associated  with  that  subroutine's  formal  parameters  and 
return  value  will  also  be  made  available,  if  they  are  declared  in  the 
designated  compool. 

Const  ra Ints : 

A  <compool-dlrectIve>  must  only  occur  immediately  after  START  or 
immediately  following  another  <corapool-directive>. 

The  <compool-declared-names>  must  have  b(‘en  declared  In  the 
designated  compool. 

A  <compool-declared-name>  cannot  be  the  name  of  a  component 
declared  in  a  type  declaration,  nor  can  it  be  the  name  of  a  formal 
parameter  of  a  subroutine. 


9.2  TEXT  DIRECTIVES 
9.2.1  COPY  DIRECTIVES 


Syntax : 


<copy-dlrectlve> 


iCOPY 

<character-llteral> 


(8.3.4) 
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Semantic^: 

The  <copy-dl rect lve>  Is  used  to  copy  the  contents  of  a  text  file 
Into  a  program.  The  <copy-d i rec t I ve>  can  he  viewed  as  a  <def Ine-cal 1> ; 
it  Is  expanded  at  the  point  of  Its  occurrence  by  substituting  the 
entirety  of  the  file  being  copied.  The  <cViaracter-l lteral>  Is  an 
Implementation-dependent  file  name. 

9.2.2  SKIP,  BEGIN,  AND  END  DIRECTIVES 


Syntax : 


<sklp-dl rect lve> 
<begln-dlrect ive> 
<end-dl rect i ve> 


::=  ISKIP  [<letter>l  ;  (8.1) 

;:=  '.BEGIN  |<letter>)  ;  (8.1) 

:  :=  ! END  ; 


Semant ics ; 

The  <skip-dlrective>  Is  used  in  conjunction  with  a 
<begln-directive>  and  an  <end-di rective>  to  cause  text  enclosed  In  the 
latter  two  to  be  ignored  In  the  process  of  compilation. 


A  <skip-directive>  with  a  <letter>  will  suppress  the  processing  of 
all  text  following  a  <begin-directlve>  containing  the  same  <letter>  up 
Co  the  matching  <end-d i rec t ive> .  A  <skip-dl rect lve>  with  no  <letter> 
refers  to  all  <beg in-di rec t ives> .  The  text  following  a  <begin- 
directive>  with  no  <letter>  can  be  suppressed  only  by  a  <sklp- 
directive>  with  no  <letter>. 


Begin-end  directive  pairs  can  be  nested.  Within  a  begin-end 
directive  set  whose  text  is  being  suppressed,  enclosed  <begln- 
directives>  are  recognized  for  the  purpose  of  matching  <end-directives> . 

Within  a  begin-end  directive  pair  whose  text  is  being  suppressed, 
<copy-dlrectlves>  and  <def lne-calls>  will  not  be  expanded. 


9.3  LINKAGE  DIRECTIVES 
Syntax ; 

<llnkage-dlrectlve>  ILINKAGE 

<symbol>...  ;  (8.2) 
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Semantics : 


The  <llnkage-dlrectlve>  Indicates  that  the  specified  subroutine 
does  nbt  obey  standard  J73  linkage  conventions.  The  <syiiibol>  string 
specifies  the  implementation-dependent  linkage  type  to  be  used  in 
linking  the  procedure. 

Constraints : 


The  <llnkage-dlrectlve>  must  only  occur  In  a  <subroutlne- 
declaratlon>  or  <subroutlne-def lnltlon>  between  the  heading  and  the 
<declaratlons>  of  the  formal  parameters. 

It  a  <subrout ine-def 1 nl t lon>  contains  a  <linkage-dlrectlve>,  every 


<subroutlne-declaratlon>  for 
<linkage-dlrect lve> . 

that  subroutine  must  contain 

the 

same 

9.4  TRACE  DIRECTIVES 

Syntax : 

<trace-directlve> 

;:=  ! TRACE 

I<trace-control>] 
<name>,...  ; 

<trace-control> 

::=  (  <boolean-formula>  ) 

(5.2 

.2) 

Semantics : 


The  <trace-directive>  provides  a  run-time  facility  to  trace  program 
flow  and  to  monitor  data  assignment.  This  "tracing"  will  be  active  from 
the  lexical  point  at  which  the  <trace-dlrective>  occurs  in  the  source 
until  the  end  of  the  scope  containing  the  directive.  Its  effect  extends 
into  nested  procedures  declared  within  this  lexical  range  of  statements. 

The  <names>  In  the  <trace-directlve>  are  the  names  that  will  be 
traced,  l.e.,  certain  uses  of  these  names  as  described  in  the  following 
sentences  will  be  noted  in  an  implementation-dependent  manner,  for 
example  on  a  symbolic  output  file.  For  statement  names,  tracing  of  the 
associated  statement  will  be  noted  each  time  the  statement  is  fallen 
Into  or  branched  to.  For  data  names,  modification  of  the  data  object 
and  Its  new  value  will  be  noted.  Modification  of  a  data  object  is 
considered  to  have  occurred  upon  execution  of  an  assignment  statement  in 
which  the  data  object  is  the  target  or  upon  return  from  a  subroutine  to 
which  the  data  object  was  passed  as  an  actual  output  parameter.  For 
tables,  modification  of  the  entire  table,  a  table  entry,  or  an  item  in 
the  table  will  be  noted.  For  blocks,  modification  of  any  data  contained 
In  the  block  will  be  noted.  For  subroutine  names,  each  call  to  the 
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Bubroutine  irflll  be  noted.  If  the  subroutine  containing  the 
<trace-dlrectlve>  is  named  In  the  directive  and  the  directive  is  placed 
Immediately  after  the  ^procedure  headlng>  or  <functlon  heading>,  entry 
and  exit  to  that  subroutine  will  be  noted. 

If  a  <trace-control>  appears  in  the  <trace-dlrectlve>,  the 
<trace-control>  formula  will  be  tested  dynamically  at  each  use  of  a 
<name>  as  defined  in  the  preceding  paragraph.  The  trace  output  is 
suppressed  If  the  formula  is  determined  to  be  false.  If  the 
<trace-control>  Is  omitted.  It  is  considered  to  be  true. 

If  two  or  more  active  <trace-dlrectives>  contain  the  same  <naroe>, 
then  the  lexically  latest  one  overrides  the  earlier  ones  for  that 
<name> . 

Constraints : 


All  <naines>  in  the  <trace-dlrective> ,  Including  names  used  in  the 
<trace-control> ,  except  for  statement  names  and  subroutine  names,  must 
have  been  declared  prior  to  their  use  in  the  <trace-dl rectlve>. 

A  <trace-dlrectlve>  can  occur  only  within  a  <statement>. 

A  <blt- formula>  cannot  be  Implicitly  converted  to  the 
<boolean-forroula>  In  a  <trace-control>. 


9.5  INTERFERENCE  DIRECTIVES 


! INTERFERENCE 

<lnterference-control>  ; 

:  :=  <data-name>  :  (2.6) 

<data-'name>  , . . .  (2.6) 

Semantics; 

The  <interf erence-dlrectlve>  Informs  the  compiler  that  it  cannot 
assume  that  the  storage  associated  wlvh  the  name  to  the  left  of  the 
colon  is  distinct  from  the  storage  associated  with  the  names  to  the 
right  of  the  colon.  In  the  absence  of  an  <lnterference-dlrectlve>  the 
compiler  can  make  optimizations  on  the  assumption  that  distinct 
<data-names>  refer  to  distinct  storage  locations.  Jf  two  <data-names> 
refer  to  the  same  storage  location,  these  optimizations  could  result  in 
erroneous  code.  If  two  <data-names>  share  the  same  storage,  an 
assignment  to  one  name  should  affect  the  value  of  the  other.  If  the 
compiler  optimizes  on  the  assumption  of  non-interference,  these 


Syntax; 

<lnterfe  rence-dlrectlve> 

<Interf erence-control> 
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semantics  might  not  be  preserved. 

The  compiler  Is  aware  of  storage  overlapping  as  a  result  of 
<speclfled-table-ltems>  and  as  a  result  of  the  arrangement  of  data 
within  a  single  overlay.  This  overlapping  need  not  be  reported  via  an 
<lnterference-dlrectlve>.  Other  Instances  of  overlap,  e.g.,  as  a  result 
of  absolute  addresses  In  separate  overlays,  must  be  stated  by  the  use  of 
an  <lnterference-dlrectlve>. 

An  <lnterference-dlrectlve>  can  occur  only  In  a  <declaratlon>. 

All  <data-names>  In  the  <lnterference-control>  must  have  been 
declared  prior  to  their  use  In  the  <interference-directlve>. 


9.6  REDUCIBLE  DIRECTIVES 
Syntax ! 

<reduclble-dlrectlve>  ::=  IREDUCIBLE  ; 

Semantics : 


The  <reduclble-dlrective>  Is  used  to  allow  additional  optimization 
of  function-calls.  A  reducible  function  Is  one  for  which  all  calls  with 
Identically-valued  actual  parameters  result  in  Identical  function  values 
and  output  parameter  values,  and  which  does  not  modify  any  data  except 
actual  output  parameters  and  automatic  data  declared  within  its  own 
body.  If  a  <reduclble-directive>  Is  used  to  designate  such  functions  as 
reducible,  the  compiler  may  detect  the  existence  of  such  common  calls, 
save  the  values  returned  from  the  initial  call  for  use  in  place  of  any 
subsequent  calls,  and  delete  these  subsequent  calls. 

Constraints : 


The  <reduclble-di rect ive> ,  If  present,  roust  be  pi?  ;ed  immediately 
following  the  semicolon  of  the  <function-heading> . 

If  a  function  designated  as  reducible  is  both  declared  and  defined, 
the  <reduci ble-directive>  must  appear  In  both  the  definition  of  the 
function  and  In  all  declarations  of  It. 


9.7  LISTING  DIRECTIVES 

9.7.1  SOURCE-LISTING  DIRECTIVES 


Syntax; 
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<nollst-dlrectlve>  :  :=  INOLIST  ; 

<ll6t-dlrective>  : ILIST  ; 

<eject-dlrectlve>  : ;=  !EJECT  ; 

Semant Ics ; 

Listing  directives  are  used  to  provide  source  listing  control 
Information  to  the  compiler.  The  <nollst-dl rect lve>  causes  suppression 
of  the  source  listing  beginning  with  the  next  source  line,  up  to  and 
Including  the  next  <list-directlve>,  which  causes  the  listing  to  be 
resumed . 

The  <e ject-dl rect ive>  causes  a  page  eject  of  the  source  listing 
before  listing  the  following  source  lines.  The  <e ject-directive>  Is 
ignored  If  the  source  listing  Is  suppressed. 

9.7.2  DEFINE-LISTING  DIRECTIVES 
Syntax ; 

<1 1 s  t inv-dl 1 ect ive> 

<1 i s t  exp-d lrectlve> 

<1 i s t  both-d i rec  1 1 ve> 

Serna ru  Ics : 

Def 1 ne-H st Ing  directives  allow  programmer  control  over  the  text  to 
be  Included  in  the  source  pi ogram  listing  for  <def i ne-cal 1 s> . 

The  text  contained  in  the  listing  for  a  particular  <def ine-call> 
depends  on  the  def ine-1 Istlng  directive  which  was  in  effect  at  the  point 
of  the  corresponding  <def lne-declaratIon>  ( not  on  the  directive  in 
effect  at  the  point  of  the  <def ine-cal 1> ) .  If  this  directive  was 
ILISTINV,  then  the  listing  contains  the  text  of  the  <def ine-cal 1> ;  if 
the  directive  was  ILISTEXP,  then  the  listing  contains  the  expanded 
string  (the  <def ine-strlng>  after  substitution  of 

<actual-def lne-paranieters>) ;  if  the  directive  was  ILISTBOTH,  then  the 
listing  contains  both  the  Invocation  and  the  expansion. 

Each  def lne-1 1  St Ing  directive  Is  In  effect  from  the  lexical  point 
at  which  It  appears  to  the  end  of  the  current  scope  or  to  the  point  at 
which  the  next  def ine-1 1 st ing  directive  appears,  whichever  is  first. 
The  default  def lne-1 istlng  directive  In  effect  at  the  beginning  of  every 
module  is  ILISTINV. 


;  :=  ILISTINV  ; 
ILISTEXP  ; 
ILISTBOTH  ; 
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Constraint ; 

<LIstlnv-directlves>,  <llstexp-dl rective6>  and 

<llstboth-dlrectlves>  may  appear  only  In  a  <declaratlon>. 

Note : 


The  effect  of  a  def Ine-llstlng  directive  for  a  particular 
<def Ine-cal 1>  is  Independent  of  whether  a  <nollst-directlve>  Is 
suppressing  the  source  listing  at  the  point  of  the  <def ine-declaratlon> 
being  Invoked. 


9.8  REGISTER  DIRECTIVES 
Syntax ; 


<base-d i rect i ve> 

:  :=  .'BASE  <data~name> 

(2.6) 

<integer-llteral>  ; 

(8.3.1) 

<isbase-dlrect ive> 

:  :=  IISBASE  <data-narae> 

(2.6) 

<integer-literal>  ; 

(8.3.1) 

<d  rop-d i rec 1 1 ve> 

::=»  IDROP 

<lnteger-literal>  ; 

(8.3.1) 

Semantics; 

Register  directives  affect  target-machine  register  allocation. 
Each  of  these  three  directives  uses  an  <integer-literal>  in  a 
target-machine-dependent  way  to  specify  which  register  is  affected. 

The  <base-directlve>  loads  the  specified  register  with  the  address 
of  the  object  corresponding  to  the  <data-name>. 

The  <lsbase-dlrectlve>  directs  the  compiler  to  assume  that  the 
specified  register  contains  the  address  of  the  data  object  corresponding 
to  the  <data-name>,  but  to  take  no  action  to  guarantee  it. 

The  <drop-dlrective>  frees  the  specified  register  for  other  use  by 
the  compiler  in  generating  code  for  subsequent  statements.  Both  !  BASE 
and  IISBASE  cause  the  compiler  to  dedicate  the  register  to  the  value  it 
currently  contains  until  !DR0P  or  the  end  of  the  current  scope  is 
encountered  . 

Register  directives  may  be  ignored  in  implementations  for  machines 
on  which  register  allocation  is  not  meaningful. 
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9.9  EXPRESSION  EVALUATION  ORDER  DIRECTIVES 
Syntax ; 

<lef trlght-dlrectlve>  ILEFTRIGHT  ; 
<rearrange-dlrectlve>  ::=•  !  REARRANGE  ; 

Semantics : 

If  a  <lef tr Ight-dlrect lve>  is  In  effect,  operators  at  the  same 
precedence  level  are  evaluated  In  lef t-to-r ight  order  within  a  given 
<formula>,  consistent  with  the  order  Imposed  by  parentheses. 

If  a  <rearrange-directlve>  Is  In  effect,  order  of  evaluation  Is 
still  constrained  by  parentheses  and  operator  precedence,  but  the 
compiler  Is  otherwise  free  to  rearrange  the  expression  for  more  optimal 
code  generation,  such  as  by  applying  associative  and  commutative  laws. 

The  effect  of  each  of  these  directives  extends  from  the  point  at 
which  It  appears  to  the  end  of  the  current  namescope  or  to  the  point  at 
which  a  different  expression-evaluation-order  directive  appears, 
whichever  is  first.  At  the  beginning  of  each  module,  a  <rearrange- 
directlve>  is  in  effect  by  default. 


9.10  INITIALIZATION  DIRECTIVES 


Syntax ; 

<lnltlall2e-dlrectlve>  ! INITIALIZE 


Semantics ; 

The  <lnltlallze-dlrective>  causes  all  STATIC  data  objects  that  are 
not  explicitly  initialized  via  an  <item-preset> ,  <table-preset> ,  or 
<block-preset> ,  to  be  preset  by  default  to  all  zero  bits. 

Its  effect  extends  from  the  point  at  which  it  appears  to  the  end  of 
the  current  namescope. 

Constraint ; 

The  <inltlallze-dlrectlve>  may  appear  only  In  <declarat lons> ,  but 
not  In  a  <table-body>  nor  in  a  <block-body-part>  nor  in  a 
<subroutlne-declaration> . 
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9.11  ALLOCATION  ORDER  DIRECTIVES 
^nt  ax : 


<orde r-dl rect ive>  ;  iORDER  ; 

Semant 1 cs : 

The  <order-directive>  directs  a  compiler  to  allocate  storage  for 
the  data  objects  In  a  block  or  ordinary  table  in  the  order  In  which 
their  declarations  appear  In  the  text  of  the  <block-body-part>  or  the 
<ordlTiary-table-opt lons> .  Lexically  declared  data  objects  that  occur 
earlier  in  text  are  allocated  physically  lower  addresses,  and  if  data 
objects  share  a  word,  lexically  earlier  data  are  allocated  to  the  left 
of  later  data.  In  the  absence  of  an  <order-directlve>,  a  compiler  Is 
free  to  rearrange  the  physical  storage  layout  for  ease  of  access  or  more 
optimal  utilization  of  memory. 

The  effect  of  the  <order-directive>  extends  from  the  point  at  which 
it  appears  to  the  end  of  the  current  block  or  table.  If  the 
<order-di rect ive>  is  in  a  block,  its  effect  extends  to  the  components  of 
any  blocks  or  ordinary  tables  contained  in  the  block. 

If  an  <order-direccive>  appears  In  an  <ordinary-table-optIons>  in  a 
<table-type-declarat ion> ,  the  ordering  extends  to  all  tables  declared  of 
that  type. 

Constraints ; 

A  block  affected  by  an  <order-directive>  cannot  contain  an 
<over lay-dec laration> . 

The  <order-dl rect ive> ,  if  present,  must  be  the  first  of  the 
<block-body-optlons>  in  the  <block-body-part> ,  or  the  first  of  the 
<ordlnary-table-options>  in  the  <ordlnary-table-body>. 
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A8PKND1X 

CROSS -RKKERENCE  INDEX 

Tills  appendix  provides  a  cross-reference  for  terminal  and 
non-terminal  constructs  In  the  J73  syntax  used  In  this  manual.  For  each 
construct,  columns  give  the  section  In  tlu?  manual  where  It  Is  defined 
and  the  sections  where  It  Is  used  or  referenced. 


Construct 

Deflnl lion 

References 

A 

2.1  .1  .3,  7.0,  8.1 ,  8 

ABORT 

4.5,  4.10,  8.2.2 

abort-phrase 

4.5 

4.5 

abort-statement 

4.10 

4  .0 

ABS 

6.3.6,  8.2.2 

abs-f unction 

6.3.6 

6.3 

absolute- address 

2.6 

2.6 

actual-def Ine-parameter 

2.4.1 

2.4.1 

ac tual-def ine-parameter-l ist 

2.4.1 

2,4.1 

actual-1 nput-parameter 

4.5 

4.5 

actual-out put- parameter 

4.5 

4.5 

actual-pararaeter-1 ist 

4.5 

4.5,  6.3 

allocation-specifier 

2.1.5 

2.1.1,  2.1.2,  2.1.4 

AND 

5.2.1,  8.2.2,  8.2.3 

and-cont Inuat ion 

5.2 

5.2 

arithmetic-operator 

8.2.3 

8.2.3 

assignment-operator 

8.2.3 

8.2.3 

assignment-statement 

4.1 

4.0 
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Construct 

Definition 

Reference* 

B 

2. 1.1. 4,  7.0,  8.1, 

8.3.2 

BAS^ 

9.8 

base-directive 

9.8 

9.0 

bead 

8.3.2 

8.3.2 

bead-size 

8.3.2 

8.3.2 

BEGIN 

1.2.3,  2.0,  2. 1.2. 3, 

2. 1.2. 4,  2.1.4,  2.5.1, 
2.5.2,  2.7,  3.1,  4.0, 

4.4,  8.2.2,  9.2.2 

begin-directive 

9.2.2 

9.0 

BIT 

6.1,  8.2.2 

bit-conversion 

7.0 

5.2 

bit-formula 

5.2 

4.4,  5.0,  5.2, 

5.2.2,  6.3.3, 

6.3.5 

bit-function 

6.3.3 

6.3 

bit-function-call 

5.2 

5.2 

bit- function- variable 

6.1 

6.1 

bit-ltem-descrlptlon 

2. 1.1. 4 

2.1 .1 .4 

bit-literal 

8.3.2 

5.2,  8.3 

bit-operator 

8.2.3 

8.2.3 

bit-primary 

5.2 

5.2,  5.2.1 

BITSINBYTE 

1.4 
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Construct 

Definition 

References 

BITSINPOINTER 

1.4 

BITSINWORD 

1.4 

BITSIZE 

6.3.8,  8.2.2 

blt-sIze 

2. 1.1. 4 

2. 1.1. 4 

blts-per-entry 

2. 1.2. 2 

2.1  .2.2 

bit-type-conversion 

7.0 

7.0 

blt-type-de script Ion 

2. 1.1. 4 

2.1.1,  7.0 

bit-type-name 

2. 1.1.4 

2. 1.1. 4,  7.0 

bit-variable 

5.2 

5.2,  6.1 

BLOCK 

2.1.4,  2.2,  2.5.1, 
8.2.2 

block-body-options 

2.1.4 

2.1.4 

block-body-part 

2.1.4 

2.1.4,  2.2 

block-declaration 

2.1.4 

2.1 

block-de reference 

6.1 

4.5,  6.1,  6.3.1 

block-1 tem 

6.1 

6.1 

block-name 

2.1.4 

2.1.4,  2.5.1,  2.6, 
5,  6.3.1,  6.3.8 

block-preset 

2.1.6 

2.1.4 

block-preset-list 

2.1.6 

2.1.6 

block-preset-va lues-option 

2.1.6 

2.1.6 

block-table 

6.1 

6.1 

block- table-entry 

6.1 

6.1 

block-table-1 tem 

6.1 

6.1 
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Const  ruct 

Definition 

Reft  r 

block-type-d or la  ration 

2.2 

2.2 

bl ock- 1  y po-nane 

2.2 

2.1  .1  .7,  2. 

bool e  an-f ornul a 

5.2.2 

4.2,  4.3,  9 

booleaii-li  teral 

oc 

5.2,  8.3 

bounds-f  vine t  ion 

6.3.9 

6.3 

BY 

4.2,  8.2.2 

by-f  omula 

4.2 

4.2 

by-or-t  hen-jilirase 

4.2 

4.2 

by-phrase 

4.2 

4.2 

BYKEF 

3.3,  8.2.2 

BYRES 

3.3,  8.2.2 

BYTE 

6.1,  6.3.4  , 

byte-f  unct ion 

6.3.4 

6.3 

byte-f  unct i on-va  r i able 

6.1 

6.1 

BYTEPOS 

1  .4 

BYTES!  Mv'ORD 

1  .4 

BYTESIZE 

6.3.8,  8.2. 

BYVAL 

3.3,  8.2.2 

C 

2.1  .1  .5,  7 , 
8.3.2 

CASE 

4.4,  8.2.2 

case-al ternatlve 

4.4 

4.4 

K4 


<  ll(  I'S 


1.4,  2.2 

.4 


f. .  2 . 2 


0,  R.  1  , 


198 


MIL-STD-1589B  (USAF) 
06  June  1980 


Construct 

Definition 

References 

case-body 

4.4 

4.4 

case-index 

4.4 

4.4 

case- Index-group 

4.4 

4.4 

case- select or- formula 

4.4 

4.4 

case-statement 

4.4 

4.0 

character 

8.1 

2.4,  2.4.1,  8.3.4, 

8.4 

character-conversion 

7.0 

5.3 

character- formula 

5.3 

4.4,  5.0,  5.2.1, 

5.3,  6.3.4 

character- function-call 

5.3 

5.3 

character- Item-description 

2. 1.1. 5 

2.1  .1 .5 

character- literal 

8.3.4 

8.3,  9.1,  9.2.1 

character-size 

2. 1.1. 5 

2.1 .1 .5 

char ac  ter- type-description 

2. 1.1. 5 

2.1.1,  7.0 

charac  ter- type-name 

2. 1.1. 5 

2. 1.1. 5,  7.0 

character- variable 

5.3 

5.3,  6.1 

comment 

8.4 

8.2 

complle-t Ime-bl t- formula 

5.1.2 

4.4,  5.0 

complle-t Ime-character-formula 

5.1.3 

4.4,  5.0 

coraplle-tlme-t Ixed- formula 

5.1.3 

5.1 

complle-t Ime- floating- formula 

5.1.2 

1.4,  5.1 

complle-t Ime-fo rmul a 

5.0 

2.1.6 

complle-t Ime-lnteger-fonnula 

5.1.1 

1.4,  2. 1.1.1,  2. 1.1. 2, 

IA5 
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Construct 

Definition 

References 

2.1  .1  .3,  2.1  .1 .4 

2.1  -1  .5,  2.1 .1 .6 
2.1  .2.1 ,  2.1  .2.2 

2. 1.2. 4,  2.1.6,  : 

4.4,  5.1,  6.3.9 

compile- t Ime-numerlc-formula 

5.1 

5.0 

compile- time-pointer- formula 

5.5 

5.0 

complle-t  Ime-status-foriTiula 

5.4 

2.1 .2.1 ,  2.1.6, 

4.4,  5.0 

complete- prog ram 

1.1 

compound-def 

2.5.1 

2.5.1 

compound-ref 

2.5.2 

2.5.2 

compound-statement 

4.0 

4.0 

COMPOOL 

1.2.1,  8.2.2,  9. 

compool-declarat ion 

2.0 

1.2.1,  2.0 

compool-dec la red-name 

9.1 

9.1 

compool-dlrective 

9.1 

9.0 

compool-dlrective-list 

9.1 

9.1 

compool-f lie-name 

9.1 

0.1 

com pool-module 

1.2.1 

1.1 

compool-name 

1.2.1 

1.2.1 

CONDITION 

8.2.2 

conditional-statement 

4.3 

4.3 

CONSTANT 

2.1.3,  8.2.2 

constant-declaration 

2.1.3 

2.0,  2.1 
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Construct 

Definition 

References 

constant-index 

2.1.6 

2.1.6 

constant-item-name 

2.1.3 

2.1.3,  6.1,  6.2 

con St ant- table-item-name 

6.2 

6.2 

con St ant- table-name 

2.1.3 

2.1.3,  6.2 

continuation 

4.2 

4.2 

control-clause 

4.2 

4.2 

control-item 

4.2 

4.2 

control-letter 

4.2 

4.2,  6.2 

cont rolled-statement 

4.2 

4.2 

control -variable 

4.2 

4.2 

COPY 

9.2.1 

copy-directive 

9.2.1 

9.0 

D 

2.1.2.?,  8.1,  8.3.2 

data-declarat ion 

2.1 

2.0,  2.1.4,  2.5.1, 

2.5.2 

data-name 

2.6 

2.6,  3.3,  9.5,  9.8 

declaration 

2.0 

1.2.2,  1.2.3,  2.0, 

3.1,  3.2 

DEF 

1.2.2,  2.5.1,  8.2.2 

DEFAULT 

4.4,  8.2.2 

default-option 

4.4 

4.4 

def aul t-preset-subllst 

2.1.6 

2.1.6 

default-sublist 

2. 1.1. 6 

2. 1.1. 6 
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Const  ruct 

Definition 

References 

def -block- Instantiation 

2.5.1 

2.5.1 

DEFINE 

2.4,  8.2.2 

def Ine-call 

2.4.1 

8.2 

def ine-name 

2.4 

2.4,  2.4.1 

def Ine-string 

2.4 

2.4,  8.2 

def In it  ion- part 

2.4 

2.4 

deflne-declaratlon 

2.4 

2.0 

def- spec  if  1  cat  ion 

2.5.1 

2.5 

def-specifica  t ion-choice 

2.5.1 

2.5.1 

dereference 

6.1 

6.1 

digit 

8.1 

8.1,  8.2.1,  8.3.1, 
8.3.2 

de reference-opera tor 

8.2.3 

8.2.3 

dloenslon 

2.1 .2.1 

2.1  .2.1 

dimension-list 

2. 1.2.1 

2.1.2,  2.1.3,  2.2 

dimension-number 

6.3.9 

6.3.9 

directive 

9.0 

1.2.1,  1.2.2,  1.2.3 
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t Oiiv.'  1  I  1  5  5  1 1  111  1 1'ner  I  o  f  I  o.  I  I ng  po  i  n I  -  -  .  - 

tonvi'i't  I  lend.  (I  pi  i.c  1  .  ion  llo.iliiig  pniiil  to  3?  bit  integer 


6/ 

08 

09 

70 

72 

73 

74 

75 

76 

77 
70 

79 

80 
81 
82 

83 

84 
05 
86 
87 
89 

91 

92 

93 

94 

95 

97 

98 

99 
101 
102 

103 

104 

105 
107 
100 

109 

110 
111 
112 
114 
116 
117 

no 

119 

121 

122 

133 

la4 

135 

136 
12/ 
138 


o  c-» 
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0.00  Convoi  I  iolcrjor  l.o  i!>  I  iiulcfl  |»rcc  i i  fluntimj  point  -  1?9 

!) .  O')  Ixf.liaiu;'  hyins  in  rci)  i s Ini'  -  -  .  .  _  _  .  -  130 

0.90  I  xcli.mijn  words  in  M.>i|istuib  -----  _  _  . 

0.91  Sinylu  prncision  cniip.iru  132 

0.9?  Conpnrc  liotwoon  I  ihiils  -  --  --  --  --  -  133 

0.93  Uoublu  prccinion  crn;pare  ----------  134 

0.94  FI  on  tiny  point  coriiiaro  -  -  ■  -  -  -  *  *  -130 

0.95  txtcndod  pi'ocision  Floating  point  compare  -----  135 

.90  No  operation  -  -  -  -  -  -  -  -  -  -  -  -137 

.97  Break  point  -------------  130 

INOtX  .  .-.1>10 
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IIOUUIS 

1  Fxpandi.'d  memory  ni.i|)p  imj  diagram 

2  IiitorrupL  syst.cm  flo\<(.liart 

3  InlerrupL  voctorir.g  system 
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TAiii  i;s 


Sinfjlo  precision  fixed  point  numbers  -  -  - 

Double  precision  fixed  point  numbers  -  -  - 

32-1)  it  floating  point  niimhors  -  _  _  _ 

'tS-bit  extenJed  floating  point  numbers 
Addressing  modes  and  instruction  word  format  - 
Processor  reset  state  ------ 

At  code  to  access  key  mapping  -  -  -  _ 

Interi'upl  dolinitions  -  -  _  .  -  - 

Input/output  channel  groups  -  -  -  -  - 

Operation  code  matrix 

f.xlendcd  operation  codes  ------ 
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I  I  Si.(»iic.  I  his  si  iiiil.ciil  ilol'iiK's  ihc  iiisiriu  tion  sol  ;ialiiiociuro  (ISA)  foi  .lirhiirno  tmiiputcrs.  It  docs  not  define 
spocilio  iiiiploinom.iiion  ilolnils  ol'a  coiii|)uter. 

1.2  Purpose.  Ilto  purpose  ofll  sdtxruincnt  is  locsi.ihlish  a  iiiiifomi  in'iruction  set  architecture  for  airborne 
compuieis  which  sh.ill  ho  used  in  Air  l-'tuce  a\ ionic  weapon  systems. 

l .  1  Anplicahililv.  I'his  standard  is  intended  to  ho  used  to  define  only  the  ISA  of  aiihorne  eoinpuiors.  System- 
unique  ivquironiems  sue  h  ;is  speed,  woii',hl,  power,  additional  ininit/ouii'iit  coinmands.  and  environmental 
operating  eharticteristics  are  defined  in  the  computer  specification  for  each  coniptiicr.  Application  is  not  restricted  to 
any  particiil.ir  a\  ionic  function  or  specilic  hardware  impleiiientaiion  by  this  si.indard.  fiencr.illy,  the  ISA  is 
applieMbIc  to,  and  shall  he  used  for,  coiiiptiters  that  perform  such  functions  as  inodertite  accuracy  navigation, 
computed  air  release  points,  weapon  deliicry,  air  rendezvous,  stores  nian.igenicnt,  .nreraft  guidance,  and  aircraft 

m. iiiiigenient.  I  his  standard  is  not  restricted  to  implementations  of  "stand-alone"  computers  such  as  a  mission 
computer  or  a  fire  control  computer.  Application  to  die  entire  range  of  ;iv  ionics  functions  is  encouraged  such  as 
stability  and  control,  display  processing  and  control,  thrust  management,  and  electrical  power  control. 

1.4  Hencfits.  I'he  expected  benefits  of  this  standard  ISA  are  the  use  and  re-use  of  available  support  software  such 
as  compilers  and  instruction  level  simulators.  Other  benefits  may  also  be  achieved  such  as:  (a)  reduction  in  total 
support  software  gained  by  the  use  of  die  standard  ISA  for  two  or  more  computers  in  a  weapon  system,  and  (b) 
software  development  independent  of  hardware  development 

2  RKFERENCEL)  rXX:UMHNTS 

Not  applicable. 


3  DEFINITIONS 

3. 1  Accumulator.  A  register  in  the  arithmetic  logic  unit  used  for  intermediate  storage,  algebraic  sums  and  other 
arithmetic  and  logical  results. 

3.2  Address.  A  number  which  identifies  a  location  in  memory  where  information  is  stored. 

3.3  Arithmetic  logic  unit  (AI.U).  That  portion  of  hardware  in  the  central  processing  unit  in  which  arithmetic  and 
logical  operations  are  performed. 

3.4  Avionics.  All  the  electronic  and  electromechanical  systems  and  subsystems  (hardware  and  software)  installed 
in  an  aircraft  or  attached  to  it.  Avionics  systems  interact  with  the  crew  or  other  aircraft  systems  in  these  functional 
areas:  communications,  navigation,  weapons  delivery,  identification,  instrumentation,  electronic  warfare, 
reconnaissance,  flight  control,  engine  control,  power  distribution,  and  support  equipment 

3.5  Rase  register.  Any  general  register  used  to  provide  the  base  address  portion  of  the  derived  address  for 
instnictions  using  the  base  relative  or  base  relative-indexed  addressing  modes. 

3.6  Bit.  Contraction  of  binary  digit;  may  be  either  zero  or  one.  In  information  theory,  a  binary  digit  is  equal  to 
one  binao'  decision  or  the  designation  of  one  of  two  possible  values  or  states  of  anything  used  to  store  or  convey 
information. 

3.7  Bvic.  A  group  of  eight  binary  digits. 

3.8  Central  nrocessine  unit  (CPU).  That  portion  of  a  computer  that  controls  and  performs  the  execution  of 
instnictions. 
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.1.9  (-  oiurol  unit.  Ihal  poilioii  ot  luirdwarc  in  ihc  fl’U  llial  sotiuoncc  cl dpcrallons.  iiiicinicis  coded 

Ills’ll  actions,  and  initiates  proper  eoinnuinds  to  otUer  paitsuCilic  tompnlcr. 

,1.10  f  ieiier.il  niiroose  register.  A  rccisier  th.il  in.iy  be  used  Ibi  arithmetic  and  lojrical  operations,  indexing, 
slulliug,  input  oiU]iul,  and  gener.il  stor.ige  of  temporary  data. 

.1.11  Index  recister.  A  registei  that  contains  a  qn.intity  for  morlilic.ilion  of  an  .aldrcss  « ithonl  pernianently 
modifying  die  address. 

1,1 2  Inoiit/oiitDiit  (I/O).  I'hut  portion  of  a  computer  whicli  interfaces  to  the  cxtei  na!  world, 

.1. 1 }  Instaiclion.  A  program  code  which  tells  the  computer  what  to  do. 

.1.14  Instruction  counter  (ICl.  A  register  in  the  CI’U  that  holds  the  address  of  die  next  instruciitni  to  be  exeeiitcd. 

3.15  Instruction  set  architecture  tISAI.  Ilte  attributes  of  a  digital  computer  as  seen  by  a  m.ichn'e  (assembly) 
laiicu.igc  piogr.immer.  ISA  ineludes  die  processor  and  input/output  instruction  sets,  their  form  its,  oper.ition  eodes. 
and  addressing  modes:  memtiry  ni.inagcmcnt  and  partitioning  if  accessible  to  the  in.ichinc  langu.ige  programmer, 
die  speed  of  accessible  clocks;  Interrupt  structure;  and  die  inaiiiier  of  use  and  format  of  all  registers  and  inemory 
locations  diat  ir  ly  be  directly  iii.iiiipulatcd  or  tested  by  a  machine  language  program.  I  his  delinitioii  excludes  the 
lime  or  speed  ol  .iny  operation,  internal  computer  partitioning,  electrical  and  physical  organi/ation,  circuits  and 
eompr'iicuts  of  tiie  computer,  imiiuifacuiring  technology,  meniory  oigani/aiion.  memory  cycle  time,  and  memory 
bus  w  idths, 

3.1b  Intcrrunt.  A  special  control  signal  that  suspends  the  normal  fliw  of  the  processor  operations  .md  allowis  the 
processor  to  respond  to  a  logically  unrelated  or  unpredictable  event. 

3.17  Memory.  Ihat  portion  of  a  computer  that  holds  data  and  instructions  and  from  which  they  can  be  accessed  at 
a  later  umc. 

3.18  Operation  code  (OPCOl)H).  lhat  part  of  an  instniction  that  defines  the  machine  operation  to  be  perfonned. 

3.19  Operand,  'fhat  part  tif  an  instruction  that  specifics  the  address  of  the  source,  the  address  of  die  destination,  or 
the  data  itscit  on  which  the  processor  is  to  operate. 

3.20  [*agc  register.  A  register  which  is  used  to  supply  additional  address  bits  in  paged  memory  addressing 
schemes. 

3.21  Programmed  innut/otitnut  (PIO).  A  type  of  I/O  channel  that  allows  program  control  of  infonnation  transfer 
between  the  computer  and  an  external  device. 

3.22  Register.  A  device  in  the  CPU  for  the  temporary  storage  of  one  or  more  words  to  facilitate  arithmetical, 
logical,  or  transfer  operations. 

3.23  Register  transfer  language  (RTl.l.  A  language  used  to  describe  operations  (upon  registers)  which  arc  caused 
by  the  execution  of  each  Instruction. 

3.24  Reserved.  Must  not  be  used. 

3.25  Sparc.  .\  framcwoi  k  for  usage  is  defined  by  the  standard  with  particulars  lo  be  defined  by  the  application 
requirements. 

.3.26  Slack.  A  sequence  of  memory  liKations  in  which  data  in.iy  be  stored  and  icM  iexcd  on  .i  last  in-first-out 
(1  Il  'O)  basis. 
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4.1,2  l)(Hihlo  invcisicm  I'lxcJ  pmiii  tial.i.  I  loulili- pu  i  ismii  I.' I'u  "  .rj  pdiitt  J  ii.i  sh.il!  be.’ 'V  L'iU.  cl  ,i,  ,i  b-  ’  m 
2's  L'c'iiiploiiK'nt  iiitogiT  tuiiiii^'i  \Mili  tlK-  most  sii  rilK  .mi  bn  i  \lSli)  dj  ibo  lii';  m  'i,i  .i-,  llir  sign  bit 

MSB  I  SB 


|S|  (MSII)  I  (ISH) 


0  1  15  16  .11 

I  samples  of  machine  representation  for  double  precision  fised  point  nunibcts  .ne  shown  in  table  II 


I A  111  r  II  Double  nrccisioii  t'lced  ntiml  luinibcrs 


Integer  | 

32-Bil 

Hexadecimal  Word 

2,147,483.647  | 

7 

F 

f 

F 

1 

f 

f 

F 

1,073,741,824  1 

4 

0 

0 

0 

0 

0 

0 

0 

2  1 

0 

0 

0 

0 

0 

0 

0 

2 

1  1 

0 

0 

C 

0 

0 

0 

0 

1 

0  I 

0 

0 

0 

0 

0 

0 

0 

0 

-1  1 

F 

F 

F 

F 

F 

f 

F 

F 

-2  1 

F 

F 

F 

F 

F 

F 

F 

E 

-1,073.741,825  | 

C 

0 

0 

0 

0 

0 

0 

0 

2,147,483,647  j 

8 

0 

0 

0 

0 

0 

0 

1 

-2.147.483,648  | 

8 

0 

0 

0 

0 

0 

0 

0 

4.1. 3  fixed  Dttini  operands.  All  operands  for  fixed  point  adds,  subtracts,  multiplies  and  di\  ides  are  integer,  A 
fixed  point  overllow  shall  be  defined  as  arithmetic  overflow  if  die  result  is  greater  than  7lll'|^  or  less  than  S000|j 
for  single  precision  and  greater  than  71KK  I  I  I-'l-K^or  less  than  8000  OOOOk,  for  double  precision. 

4.1.4  Kc.sults  on  fixed  Doiiil  overflow.  On  fixed  point  operations  which  cause  overflow,  the  operation  shall  be 
performed  to  completion  as  if  the  MSMs  are  present  and  die  16  I.SIls  for  single  precision  or  the  32  I.SHs  for  double 
precision  shall  be  retained  in  die  proper  rcgisicr(s).  Division  by  zero  shall  produce  a  fixed  point  overllow  and 
return  results  of  all  zeros. 

4.1.5  Moating  point  data.  Moating  point  data  shall  be  represented  as  a  32-bit  quantity  consisting  of  a  24-bit  2's 
complement  mantissa  and  tin  8-bit  2's  complement  exponent. 
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MSU  I  Ml  MSli  LSB 


|S|  Mantissa  I  txponent  | 


01  23  24  31 

I  li'.iliiu;  poiMi  iiuinbcrs  arc  rcpicsoiUcd  .is  a  fr.ictional  nianliss;i  limes  ?.  raised  Ui  ihe  pov/cr  of  the  exponent.  All 
tlo.itnr;  |iiiiiii  lunnbers  are  .issnmed  nonn.ili/.ed  or  lloiilnip  point  /ero  .it  lire  liegininnt;  ol'a  floating  point  operation 
.ind  llie  lesnlls  of  all  llo.iliiii!  point  operalions  .irc  lurmiali/ed  (a  iioi  iii.ilixed  llo.itiiig  point  luiinher  li.is  the  sign  of  Uie 
ni.intiss.i  .irid  tile  next  hit  of  opposite  value)  or  floating  point  zero.  A  tloating  point  /eio  is  defined  as  IKKIO  (XlOOif,, 
tli.it  is,  Ml  iii.nuiss.i  and  a  zero  exponent  (OOk,).  An  extended  lloatn  g  point  zero  is  define,  i  as  tJilOO  0000  IIOOOk,, 
that  IS,  a  zero  mantissa  and  a  zero  cxpiinenl.  Some  examples  of  the  inaUinie  represent. ition  for  32  bit  lloating  point 
luiiiihers  .ire  shown  in  table  111. 


I'AliMi  III.  32-bit  arating  point  ntmibers 


Hexadecimal  Notation 


I  Decimal  Number  |  Mantissa  EXP 

I  0.9999998  x  2*^  1  7FFf  FF  7F 

!  0.5  X  2^^^  I  4000  00  7F 

I  0.625  X  2'*  I  5000  00  04 

I  0.5  X  2^  I  4000  00  01 

I  0.5  X  2°  I  4000  00  00 

1  0.5  X  2'^  I  4000  00  FF 

I  0.6  X  2'^^®  I  4000  00  80 

I  0.0  X  2®  I  0000  00  00 

I  -1.0  X  2®  I  8000  00  00 

I  -0.5000001  X  2"128  I  pp  gg 

I  -0.7500001  X  2^  9FFF  FF  04 


4.1  .ft  Hxicndcd  precision  fliiating  noint  data.  Extended  floating  point  data  shall  be  represented  as  a  48-bit  quantity 
consisting  if  a  40-bit  2’s  complement  mantissa  and  an  8-bil  2’scomplcment  exponent.  Ihe  exponent  bits  24  to  31 
lay  between  the  split  mantissa  bits  0 10  23  and  bits  32  to  47.  flic  most  significant  bit  of  the  mantissa  is  the  sign  bit  0, 
and  tlic  least  significant  bit  of  the  mantissa  is  bit  47. 
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I  I  Mant issa  |  1  Mant  issa  | 

I S I  MS  I f  xponen 1 1  I S  | 

01  23  24  31  32  47 

SoiiK'  c\ani[)lcsi)f  llic  macliir  '  loprcscntation  of48-bii  cxicndcd  floating  point  mnnhcrs  arc  sliovni  in  uiblo  IV. 

rAlll.F  (V.  48-bit  extended  lloatiiie  noini  nuinbcrs 


Hexadecimal  Notation 


Decimal  Number 

1  Mantissa  (MS) 

1  Exp  1 

Mantissa  (LS) 

«  0.5  X  2*^^ 

1  400000 

1  I 

0000 

0.5  X  2° 

1  400000 

1  00  1 

0000 

0.5  X  2”* 

1  400000 

- 1  1  -- 

1  FF  1 

0000 

0.5  X  2'^^® 

1  400000 

—  1  . . 1  ■■ 

1  00  1 

0000 

-1.0  X  21^' 

1  800000 

■  ■  1  . . 1  ■■ 

1  7F  1 

0000 

o 

csj 

K 

O 

1  800000 

1  1 .. 
1  00  1 

0000 

-1.0  X  2"^  . 

1  800000 

1 . 1  ■■ 

1  EF  I 

0000 

-1.0  X  2'^^® 

1  800000 

1  . . .  1  ■■ 

1  00  1 

0000 

0.0  X  2® 

1  000000 

—  1  1 .. 
1  00  1 

0000 

-0.75  X  2'’ 

1  AOOOOO 

1  1  -- 
1  EF  I 

0000 

For  both  floating  point  and  extended  floating  point  numbers,  an  overflow  is  defined  as  an  exponent  overflow  and  an 
underflow  is  defined  as  as  exponent  underflow. 

4.1.7  lloating  point  operands.  All  operands  for  floating  point  instruetions  must  be  normalized  or  a  floating  point 
zero.  A  floating  point  overflow  shall  be  defined  as  exponent  overflow  if  the  exponent  is  greater  Uian  7K](,.  Ihe 
results  of  an  operation  which  causes  a  floating  point  overflow  shall  be  die  largest  positive  minibcr  if  the  sign  of  the 
resulting  mantissa  was  ositivc.  or  shall  be  the  smallest  negative  number  if  the  sign  ol  the  resulting  mantissa  was 
negative.  Linderflow  shall  be  delined  as  exponent  underflow  if  the  exponent  is  less  than  80|,,.  I  he  results  of  an 
operation  which  causes  a  floating  point  underflow  shall  be  llteiting  point  zero.  Separate  intci  nipts  are  set  for 
overflow  and  underflow,  tlnlv  the  floating  point  insmictions  shall  set  the  tinderllow  'nicrnipt. 

4.1.8  rruncation  of  floating  point  results.  All  floating  point  results  shall  be  tnincated  tow  ard  negative  infinity. 

4.1.9  Kcsults  of  division.  Ilie  sign  of  anv  non-/cro  remainder  is  the  s;ime  as  the  dividend  lor  all  division 

instniclions:  the  remainder  is  onlv  .icccssible  for  single  piecision  integer  div ides  with  Ifi  bit  div  idends  and  for  single 
precision  integer  divides  with  1.’  bit  dividends. 
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4  ’  liisinn-imn  Imiii.iis.  Six  ti.isk  iiixli uctiuii  lomi.il'. 'Ii.ill  Mippurl  10  ,iir1  12-hit  m  .liiKliuns.  llic  opcioilion  code 
(opcoile)  sh.ill  iioiin.ill>  consist  ofllic  S  most  siijnilk.int  bits  ot  the  instiuction. 

4  2,1  Kei'isier  to-rcmstei  ronn.it.  I  he  iei>ister-to-repisiei  foriii.it  is  a  ih  bil  instruction  consisting  of  .in  8  bil 
opcode  .ind  ivm  4  bit  general  regisi.'i  (GU)  fields  tint  Ijpic.illy  specify  any  of  16  general  registers.  In  addition,  these 
fields  may  cc'iitain  a  shift  count,  condition  code,  opcode  extension,  bit  number,  or  die  operand  for  immediate  short 
iiistinctions. 

MSB  LSB 


I  Opcode  I  GRl  I  GR2  | 


0  7  8  11  12  15 

4.2,2  Instruction  counter  relative  format,  Ilic  Instruction  Counicr(IC)  Relative  1-ormai  is  a  16-bit  instruction 
consisting  of  an  8-bit  opcode  .inJ  an  8-bit  displacement  field. 

MSB  LSB 


Opcode  I  Displacement  | 


0  7  8  15 

4.2..1  B.ise  relative  format.  Hie  b.isc  relative  instruction  format  is  a  16-bit  instmetion  consisting  of  a  6-bit  oiKodo, 
a  2bii  biiso  register  field  and  an  8-bit  displacement  field.  Ihc  base  register  (BR)  field  allows  the  designation  of  one 
of  four  different  registers. 

MSB  LSB 


I  Opcode  I  BR  |  Displacement  | 


0 

5  6 

7  8 

15 

BR 

=  0 

impl ies 

general 

register 

12 

BR 

=  1 

impl Ies 

general 

reg i ster 

13 

BR 

=  2 

impl ies 

general 

register 

14 

BR 

=  3 

imp1 ies 

general 

register 

15 

4.2.4  Base  relative  indexed  format.  Ilie  base  relative  indexed  instruction  format  is  a  16-bit  instruction  consisting 
of  a  6-bit  opcode,  a  2-bii  base  register  field,  a  4-bit  opcode  extension  and  a  4-bit  index  register  field.  Hie  base 
register  ( BR)  field  allows  the  designation  of  one  of  four  different  base  registers  and  the  index  register  (RX) 
field  allows  the  designation  of  one  of  fifteen  different  index  registers. 
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I  Opcode  I  BR  I  Op.Fx.  I  RX  | 


0 

5  6 

7  8 

11  12 

15 

HR 

=  il 

imp  1 ies 

geneeal 

rey  i  s  Le  i' 

12 

BH 

=  1 

impi  ies 

general 

reg  ister 

13 

BR 

-  2 

imp  1  ies 

genera  1 

reg  i  s  t  er 

J4 

HR 

=  3 

imp  1  ies 

genera  I 

reg  ister 

15 

RX  =  0  implies  no  indexing 

4.2.5  l.init;  insiniclion  fonTi;ii.  IFic  !  ong  Insinitiion  l-omi.ii  is  a  .22-bii  insiruciion  consisting  of  an  K-hii  oiKode.  a 
4-bU  general  register  field.  .i  4-l)it  index  register  field  and  a  16  bit  address  field. 

MSB  1  SB 


I  Opcode  I  GRl  I  RX  j  16-Bit  Address  Field 


0  7  8  11  12  15  16  31 

lypicallj,  OKI  is  one  of the  16  general  registers  on  which  the  instruction  is  performing  die  operation.  RX  is  one  of 
the  15  general  registers  being  used  as  an  index  register.  Ihc  !6-bit  address  field  is  either  a  full  16-bil  memory 
address  or  a  16-hit  operand  if  tlie  instruction  specifics  immediate  addressing. 

4.2.6  immedsite  orreode  extension  format.  1  he  immediate  opcode  extension  format  is  a  .12-bit  instruction 
consisting  of  an  8-bit  opcode,  a  4-bii  general  register  field,  a  4-bii  opcode  cxtcnsmn  and  a  16  bit  data  field. 

I  ypically.  CiR  1  is  one  of  the  16  general  registers  on  which  the  instmetion  is  performing  the  operation.  Op.  Fvx.  is  an 
opcode  extension. 

MSB  LSB 


I  Opcode  I  GRl  I  Op. Ex.  |  16-Bit  Immediate  Data  | 

0  7  8  11  12  16  16  31 

4.3  Addressing  modes,  'fable  V  specifies  the  instruction  word  format,  the  I  Icrivcd  Address  (DA),  and  the  Derived 
Operand  (IX))  for  each  addressing  mode  that  shall  be  implemented.  Ihc  smallest  addressable  memory  word  is  16 
bits;  hence,  the  16-bit  address  fields  allow  direct  addressing  of  64K  (65.536)  words.  Ihcre  is  no  restriction  on  the 
location  of  double  word  operands  in  memory. 

4.3.1  Register  direct  (R).  An  addressing  mode  in  which  the  instruction  specified  register  contains  the  retiiiircd 
operand.  (With  the  exception  of  this  address  mode.  DA  denutes  a  memory  .iddrcss.) 

4.3.2  Memory  direct  (D).  An  .tddrcssing  mode  in  which  the  instruction  ci'niains  the  mcnioiy  .iddrcss  of  tlic 
operand. 

4.3.3  Memory  direct-indexed  (I  )X).  .An  .iddrcssing  mode  in  which  the  memory  .iddicss  of  the  regiiircd  oper.ind  is 

specified  In  the  sum  of  the  cinitent  of  .in  index  legistei  and  the  instniction  .iddrcss  field.  Rcgisteis  Rl.  R2 . KI5 

m.iy  be  specified  for  indexing. 
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4.  V4  NK'imuv  iihIiiccI  ( I).  An  .nldrossing  iiuiik’  in  whith  llio  instruclion  spivilknl  nicitKiiy  Liml.iins  llio 

iddK'Ns  oi  ihc  u\|uuvd  opoinnd. 

4.1.5  NK'ijU’iy  iMiJnveL".iil'  nro  indo.xiim  ( IX).  .An  nddivsMng  nuido  in  whi'.h  die  sum  of  the  I'uncnt  nl  .i  spi.xiliod 
iiulox  ivuisloi  ,iiul  tin'  iiisluiclnin  .kKIivss  iK-ld  is  iho  .iddrs  .>  ot  die  .iJdrcss  (il  die  leqmred  i  [lei.iiid  Kegisiei  s  K 1 . 
R2 . K15  m,u  bespecided  ten  pic-indcxing. 

4.. 1,fi  lininedi.ile  liiim  (IM).  Ilieiv  sh.ill  be  iw  u  met  beds  el'  Inimedi.iio  1  eng  nddrcssmg:  ene  h  hieh  .illevss 
indexing  and  one  utiieli  does  nei  I  he  index. ihle  lei  in  el'nitiiiedi.iie  .iddies' in.'  Is  delined  in  i.iMe  V,  II  [be 
speeltled  Index  register.  KX  Is  net  eqiKil  lo  /ere.  the  eenienl  el  l<\  is  ndiled  le  die  miniedi.ite  li'  ld  le  lei  in  die 
required  epeiMiid;  otherwise  the  inimedi.ite  ne|d  sent. mis  the  rs'<niiied  eper.ind. 

4. . 1.7  Imniedi.ite  short  ( ISI.  .\ii  .iddiessing  mode  in  wliieli  the  leiimred  (4-hil)  operand  is  tom. nned  «  nhiii  aie  ( 16- 
hit)  instriietien.  Ihere  sh.ill  he  two  metliods  el'  Iniiiietli.ite  Sheri  .iddressing,:  one  uliith  iiileipreis  the  eonieiu  el  the 
iinniedi.ite  field  as  positixe  dal.i.  .mil  a  setoiid  uliieli  inieiprels  the  toiiicni  of  limnedi.itc  lield  .is  nep.nixe  d.n.i, 

4. . 1.7.1  Innnedl.ite  sluiri  nesliixe  (ISP).  I  he  imniedi.ite  operand  is  treated  as  a  positive  integer  between  1  .nid  10. 

4. 3. 7. 7  Imniedi.ite  short  nee.itive  ( ISN).  Hie  inimedi.ite  operand  is  treated  as  a  negative  integer  between  1  and  lb. 
Its  intern.il  tiirin  sh.ill  be  .i  2  s  coniplenient.  sign-extended  16-bit  miniber. 

4.3.8  Instriieiion  eounter  relailvc  (ICR).  I  his  .iddressing  mode  is  used  for  16  bit  branch  instriietions.  Hie 
contents  ol  the  iiistruetioii  eounter  minus  one  (i.o..  the  address  of  the  current  instrutiion)  is  .added  to  the  sign 
extended  8-l)it  displaeenieiit  Held  of  the  instruction.  I'lie  sum  points  to  Llic  memory  .iddress  to  which  control  may  be 
tr.insferrod  if  .i  br.inch  is  oxeciitod.  Iliis  mode  allows  addressing  xvitJiin  a  memory  region  of  80|f,  to  7K](,  words 
relative  to  the  address  of  the  eurrent  instiaiction. 

4.3.9  llnsc  relative  (R).  An  .addressing  mode  in  which  the  content  of  an  instiaiction  specified  base  reg  's  .iddcd 

to  die  8-bit  displacement  f/cld  ol'thc  (Ift-hit)  insiniciion.  I  he  di.splaremcni  field  is  taken  to  be  a  posi'b .  .i-hcr 

between  0  and  255.  I'hc  sum  points  to  the  memory  address  of  die  required  oper.and.  Hiis  mode  allow  .dv  ig 
within  ;i  memory  region  of  256  words  heginnnig  .it  the  address  pointed  to  by  the  b.ase  register. 

4.3.10  liase  rcl.iiivc-lndcxcd  ( HX).  Hic  sum  of  the  contents  of  a  specified  index  register  and  a  specified  base 

register  is  the  .iddress  of  die  required  operand.  Registers  Rl.  R2 . R15  may  be  specified  for  indexing. 

4.3.1 1  finaial  (S).  The  special  .addressing  mode  is  used  where  none  of  die  other  addressing  modes  are  appli  able. 
4.4  Registers  .ind  support  fcatorcs. 

4.4.1  General  registers.  Ilic  instruction  set  shall  support  a  iiiinimuin  of  16  rcgistcrs(R0  through  R15).  Hic 
registers  may  he  used  as  accuiiuilalors,  index  registers,  b.ase  registers,  temporary  operand  memory,  and  stick  pointers 
with  the  following  restrictions: 

a.  Only  registers  Rl,  R2 . R15  may  be  used  as  index  registers  (RX). 

b. Only  four  registers,  R12,  R13.  R14,  and  R15  may  be  used  as  base  registers  for  instructions  having  the 
Rase  Rcl.ilixe  address  mode. 

C.R15  is  the  implicit  st.ack  pointer  for  the  Rush  and  Pop  Multiple  instructions  (Opcode  8I-'|f,  and  9F,^). 
d.  Ihe  gcner.il  registers  are  not  in  the  logic.il  memory  , iddress  space. 

c  liistriii  lions  having  the  It.ise  Rel.iiixe  .iiklrcssmc  mmle  haxe  a  single  .iccumulaior,  Ihe  rogistci  pair(R(), 

R 1 )  Is  the  .iccuimil.ilor  h.nluiibk'  piei  isnm  ,i,id  ilo.itiiig  ponil  opei.ilions.  Register  R2  is  ihc 
.iccimuililor  for  sincle  piei  imhii  "p.  i. minis  except  nniliiply  ,ind  div  loe  h.ise  lel.ilixe  .iKo  use  R  V 
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Ulc  u.'gl^^cl^  sli.ill  ruiKli(iii.ill\  .ippc.ir  lo  b..'  10  l)U^  iii  loiiiilh  I m  iiisIUk. liuiis  i.  (piinng  .i  I’-liil  upi. ratKin, 

.idj.ii.\.'iU  uyisK'is  sh.ill  bo  o()iicaloiMU\l  (u  form  ol’lixlivo  f/  bit  icp.islors.  I nsli  111111111-.  10.1111111114  -18 -bit  oponuion 
sb.ill .  oiiL.iloii.ito  ibroo  .nljaccni  lop.isiois  10  form  ,11)  clloctivo  48  bit  rogisici . 

WI1011  lOLpsiois  ,iro  coiK’.Ucnalod,  the  ro.oistcr  spetdiod  by  iho  iiisiruotioii  sh.ill  rcprosoiit  the  most  siniiilio  ini  word. 

I  lio  lojisior  set  wr.ips  iioond,  tlt.ii  is,  U 15  coneatcii.ilcs  witlt  RO  for  J2  bit  opoi.itioiis  .i.id  1<15  coiie.iteii.itcs  with  RO 
.ind  Rl  fill  48-bit  operations. 

4.4.2  Soeeial  registers.  I  hc  instrueiioiis  shall  make  use  of  die  following  special  registers;  instruction  counter, 
si  nus  word,  fault  register,  interrupt  mask,  pending  interrupt  register,  and  itiput/oiitpiit  interrupt  code  registers. 

4.4.2. 1  Instruction  eoiniter  IIC).  A  16-bit  register  used  for  program  sequencing.  It  .illims  instructions  within  a 
r.ingc  III  65,5.16  woi  Js  to  be  executed.  It  is  external  to  the  general  registers.  It  is  saved  in  mcmoi-y  when  an  interrupt 
IS  serv  iced. 

4.4. 2. 2  Status  word  (SWI.  Ilic  instruction  set  shall  reference  a  16-bit  status  word  register  whose  state  is  defined  by 
some  prior  event  oecui  rence  in  die  computer,  llte  figure  below  indicates  the  formal  for  the  SW  with  the  following 
paragraphs  describing  the  meaning  of  the  Condition  SuitusfCS)  field,  reserved  bits,  the  Processor  Suite  (PS)  field, 
and  the  Address  State  (AS)  field. 


CS  I  Reserved  1  PS  (  AS  1 


0  34  78  11  12  15 

CS  Hits:  A  tiiur-bit  field  (bits  0  through  3)  of  the  status  word  shall  be  dedicated  to  instruction  results  (i.c., 

instruction  status  bits)  and  is  defined  as  condition  status  (CS).  Hits  0,  1,2,  and  3  sliall  be 
identified  as  C,  P,  /„  and  N,  respectively,  and  their  meanings  arc  given  by  die  following  register 
transfer  desci  iption: 

C  =  (CS)o  =  1  if  result  generates  a  carry  from  an  addition  or  no  borrow  from  a  subtraction 
P  =  (CS)i  =  1  if  result  is  greater  than  (zero) 

Z  =  (CS)2  ==  1  if  result  is  equal  to  (zero) 

N  =  (CS)3  =  1  if  result  is  less  than  (zero) 

Reserv  cd  Hits:  Bits  4  dirough  7  of  the  status  word  shall  be  reserved. 

PS  Bits;  A  fiiur-bn  field  (bits  8  through  11)  of  the  status  word  shall  be  dedicated  to  the  processor  state  (PS) 

code,  llic  code  value  defined  by  die  PS  shall  be  used  for  the  following  two  functions; 

For  implementations  which  include  the  memory  access  lock  feature  of  the  expanded  memory 
addressing  option  (see  paragraph  4.5. 2.2).  PS  shall  define  the  memory  access  key  code  for  all 
instructions  and  operand  references  to  memorv.  References  to  memory  during  the  interrupt 
recognition  sequence  for  vector  table  pointer  fetches  and  linkagc/servicc  parameter  siorc/rcad 
references  shall  not  use  PS  to  define  the  memory  access  key  code,  but  shall  use  an  imiilied  PS  =  0 
value. 

PS  sh.ill  determine  the  legal/illcgal  criteria  for  privileged  instructions.  When  PS  -  0  and  a 
privileged  instruction  execution  is  attempted,  the  instruction  shall  be  legal  and  shall  be  executed 
properly  .is  defined.  When  l*S/t:C  and  a  privileged  instruction  execution  is  attempted,  the 
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instruclion  si i. ill  he  illegal,  shall  be  aborieJ,  and  ihc  privileged  instruelion  fault  bit  in  the  fault 
register  (I'l  n,)  shall  be  set  to  one. 

AS  bits;  A  four-bit  field  (bits  12  through  IS)  of  the  st.itus  word  shall  be  dedicated  to  the  address  state  (/\S) 

code,  l  or  iinpicinentaiions  which  do  not  include  die  expanded  nieiiuiry  addieeving  option,  .m 
address  stiite  fault  shall  be  gencr.ned  lor  .in>  operation  wbit  h  attempts  to  inodiiv  AS  to  a  non  /ero 
value,  l-or  iinplernemalioiis  vchich  include  the  expanded  memory  .tddiessine  option,  AS  sli  iil 
define  the  gioup  (pair)  of  page  register  sets  to  be  used  for  .ill  insiiuction  and  operand  reldrenccs 
to  ineniory.  kefcrenccs  to  memory  during  die  interrupt  leeognitioii  sctiueiiee  for  \eetoi  table 
pointer  fetches  and  ser\  ice  ptirametcr  load  references  sh.ill  not  use  AS  to  dcliiie  the  operand  p.igc 
register  set,  but  shall  use  an  implied  AS  =0  value,  live  liiik.ige  parameter  store  lefcreiicessh.ill 
use  the  AS  field  of  die  new  status  word,  for  partial  iniplcmentaiions  which  include  less  tli,  a  lb 
groups  of  page  register  sets  for  thcoxpaiulod  memory  addressing  option  (see  p.ii  .igrapli  4  S,2.3), 
the  address  state  fault  hit  in  the  fault  rceistcr(l-’l  |[)  shall  he  set  to  one  if  any  operation  .iticmpcs 
to  establish  an  AS  value  that  is  not  unplemcnied. 

4.4. 2. 3  Fault  register  (I  'l  I.  'Ihe  fault  register  is  a  16-bit  register  used  for  indicating  machine  error  condititins.  Iho 
logical  OK  01  the  fault  register  bits  is  used  to  generate  the  machine  error  interrupt,  llic  fault  icgisicr  shall  he  read 
and  cleared  by  an  XIO  instinciion.  If  a  particular  fault  bit  is  not  implemented,  then  die  bit  shall  be  set  to  zero.  Ibe 
fault  bits  shall  be  assigned  as  specified  in  tlie  following: 

01  234  56  7  8  9  10  11  12  23  14  15 


I  MEMORY  1  PARITY  |  I/O  |SPARE1  ILLEGAL  |RES.|  BITE 

IPROTECT  1  III  II 


1110  bits  shall  have  the  following  meaning  when  .set  to  one  (I); 


Bit  0; 

Bill: 

Bit  2: 
Bit  3: 
Bit  4; 
Bit  5; 

Bit  6: 

Bit  7; 
Bit  8; 
Bit  9; 


CPU  Memory  Protection  Fault,  llie  CPU  has  encountered  an  access  faulL  write  protect  fault,  or 
execute  protect  fault, 

DMA  Memory  Protection  F'auli.  A  DMA  device  has  encountered  an  access  fault  or  a  write 
protect  f.iult. 

Memory  Parity  Fault. 

I’lO  Channel  Parity  Fault. 

DMA  Channel  P-rity  Fault. 

Illegal  I/O  Command  Fault.  An  attempt  has  been  made  to  execute  an  unimplcmcnicd  or  reserved 
I/O  command. 

PIO  I  ransmission  Fault.  Other  I/O  error  checking  devices,  if  used,  may  be  OKed  into  this  bit  to 
indicate  an  error, 

Sparc. 

Illegal  Address  Fault.  A  memory  location  has  been  addressed  which  is  not  physically  present. 
Illegal  Instrticiion  Fault.  An  attempt  has  been  made  to  execute  a  reserved  code. 
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Uii  10,  I’l  i\  ilogcJ  Insiructidii  I'.uilt.  An  iiUcinpl  has  ba'ii  made  U)  cxeciilc  a  privileged  insliutdoii  with 

rs^o.^ 

Uil  11:  Address  Stale  Fault.  An  attempt  has  been  made  to  establish  an  AS  value  for  an  unimplcmcnied 

page  register  set. 

Hit  12:  Reserved. 

Bit  13;  Built-in  l  est  Fault.  Hardware  built-in  test  equipment  (Bl  li-)  error  has  been  detected. 

Bit  14-15:  Sparc  Bl  I  H.  These  bits  arc  for  use  by  tlic  designer  for  future  defining  (coding,  etc.)  the  BITH 

error  wbieh  is  detected.  'Iliis  can  be  used  with  Bit  13  to  give  a  more  complete  error  description. 

4  4.2.4  Interrupt  mask  (MK).  Hie  interrupt  mask  register  is  software  controlled  and  contains  a  mask  bit  for  each 
of  the  system  inierrLipts.  The  interrupt  system  Is  defined  in  paragraph  4.6. 

4.4.2. 5  Pendiim  iiiterriint  register  (PH.  nie  pending  interrupt  request  register  is  software  and  hardware  controlled 
and  contains  tlic  pending  interrupts  that  are  attempting  to  vector  tlic  instruction  counter.  A  pending  interrupt  is  set 
by  a  sy  stem  interrupt  signal.  The  pending  tnicrnipi  bit  that  generates  the  inieraipi  request  is  cleared  by  hardware 
action  during  the  interrupt  processing  prior  to  initiating  software  at  the  address  defined  by  the  new  IC  value.  The 
register  may  be  set.  cleared,  and  read  by  the  I/O  instructions. 

4.4. 2.6  Input/outniit  intermpt  code  registers  (lOirKoniional).  1110  input/outpiil  interrupt  code  registers,  if 
implemented,  arc  used  to  indicate  which  channel  generated  the  input/ouiput  interrupt.  One  register  is  assigned  for 
each  of  the  two  input/output  interrupts.  Fiach  register  is  set  by  hardware  to  reflect  the  address  of  die  highest  priority 
channel  requesting  that  level  of  intcrnipi.  ibe  address  shall  be  for  channel  number  0.  0F)j  for  channel  number 
15.  7F|(,  for  channel  number  127,  etc.  Ibe  lOlCs  shall  not  be  altered  once  the  intcrnipi  sequence  has  commenced 
until  they  are  read  by  an  I/O  instruction. 

MSB  LSB 


Spare  |  Channel  Code 


0  7  8  16 

4.4. 2.7  Page  registers  (optional).  Up  to  256  sixteen  bit  registers  for  optional  expanded  memory  addressing. 

4.4.2. 8  Memory  fault  status  register  (MFSR)fontional).  The  memory  fault  status  register  provides  Uic  page 
register  selection  designators  associated  with  memory  faults,  ibe  page  register  designators  (below)  captured  by  the 
MFSR  are  valid  for  die  memory  reference  causing  die  fault. 


I  LPA  I  RESERVED  1I0|  AS  j 


034  10  11  12  15 

LPA;  Address  of  page  register  within  the  set 

RFSFRVHl):  Must  not  be  used, 

lO:  Instruction/operand  page  set  selector  (1  =  Insiruclion). 

AS:  Address  of  selected  group. 
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4,4. .1  Sl.ick,  'Fhc  insiruclion  set  shall  support  a  stack  incthanism.  ITic  operation  of  the  slacking  mcclianism  shall 
ho  such  that  the  "last-in,  flrst-out"  concc'iit  is  used  (or  adding  items  to  the  slack  and  ihc  Slack  I’uiiiierCSH)  legisier 
always  tonlains  the  memory  address  wlicrc  the  last  item  is  stored  on  the  stack.  Ihe  stack  prouik  s  lor  nested 
subroutine  linkage  using  register  15.  Ihc  stack  shall  also  reside  in  a  user  defined  memory  aiea.  I  wo  insuuclions 
sh.ill  use  regisior  number  15  (If  15)  as  the  implied  system  st.ick  pointer:  Push  Multiple  registers.  PSI  IM  (see  page 
87),  and  Pop'.Multiple  registers,  POPM  (sec  page  77).  'Ihc  slack  expands  linearly  toward  /ero  as  Items  are  .idiled  to 
it. 

Two  instructions.  Stack  1C  and  Jump  to  Subroutine,  SJS  (see  page  68),  and  Unstack  1C  and  Reiuiii  froui  Subrouline, 
URS  (see  page  69)  allow  the  programmer  to  specify  any  of  the  16  general  registers  as  the  stack  pointer.  I  hc  memory 
block  iininediatcly  preceding  the  stack  area  may  be  protected  (by  user  using  memory  protect  RAM),  thus  providing 
a  means  of  knowing  (memory  protect  interrupt)  when  the  stack  limit  is  exceeded.  Ihc  stack  shall  be  addressed  by 
the  Stack  1C  and  Jump  to  Subroutine,  Unstaek  1C  and  Return  from  Subroutine,  Push  Multiple,  and  Pop  Multiple 
instructions. 

4.4.4  Prt.Kcssor  initiali/ation. 

4.4.4.1  Processor  reset  state,  fable  VI  defines  the  processor  reset  state: 


fADl.HVI.  Processor  reset  state 


Reg  is ter /Dev  ice/ Function 

Instruction  Counter 

Status  Word 

Fault  Register 

Pending  Interrupt  Register 

Interrupt  Mask  Register 

Seneral  Registers 

Interrupts 

Timers  A  &  B 

Page  Registers 

Page  Registers  AL  Field 

Page  Registers  W  Field 

Page  Registers  E  Field 

Page  Registers  PPA  field 

Memory  Protect  RAM 

Start  Up  ROM 

DMA  Enable 

Input  Discretes 

Trigger  Go  Indicator 

Discrete  Outputs 


Condition  After  Reset 

All  zeros 
All  zeros 
All  zeros 
All  zeros 
All  zeros 
Indeterminate 
Disabled 

Started  and  all  zeros  ' 
Group  0  enabled  ^ 

All  zeros  * 

Zero  ' 

Zero  * 

Exact  logical  to  physical  * 
Disabled  and  all  zeros  ’  ^ 
Enabled  ’ 

Disabled  ' 

Indeterminate  ’ 

Started  * 

All  zeros  * 


’  If  implemented  (optional) 

^  Main  Memory  Globally  Protected 


4.4.4. 7  Power  iin.  Upon  application  of  power,  the  processor  shall  enter  the  reset  state,  the  normal  power  up 
discrete  shall  be  set  (if  im|ilcmenied),  and  execution  shall  begin. 

4  4  5  Interval  tuners  (oniion.il).  If  impicmciiicd.  then  two  interval  limcis  shall  be  pros ided  in  the  computer  and 
shall  be  leterred  to  as  I  mier  5  .lud  I  imci  I!.  Uoih  limcrsc.m  be  Ui.idcd,  slopped,  st.irtcd,  .and  re.id  with  die 
romiminds  ilesenbcd  m  the  NK)  par.ignipb  (see  p.ige  ?')).  Ihe  two  timers  sh.ill  be  Ih-bn  eounieis  wbieh  operate  as 


It 
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loll()^^s.  I  JTccti^cly,  ,1  one  is  autoni.ilit.illy  added  lo  ihc  least  sittiiilieain  l)it  of  die  timer.  Hit  fifteen  is  the  least 
significant  bit  and  shall  represent  the  spetified  inereinent  saliic  of  that  timer  I.e..  either  10  or  100  microseconds.  An 
inteiriipt  request  is  generated  when  a  timer  increments  Irom  H  l■'l•■|,^  to  OOIK)„,.  Alter  power  up,  if  the  timers  arc  not 
loaded  by  software,  then  an  interrupt  request  is  gcner.ited  after  65,5.10  counts.  A  stiiuple  of  the  16-hit  counting 

sequence  (shown  in  hex)  is  0000.  0001 . 7FH-',  8000 . I'l  l-I-'.  (K)00 .  At  system  reset  or  power  up,  the  timers 

are  initiali/cd  in  accordance  with  paragraph  4.4.4. 1.  Ilie  timers  arc  halted  when  a  bicakpoint,  liPl'(sce  page  138), 
instruction  is  executed  ;ind  tire  console  is  connected. 

4.5  Memory. 

4.5.1  Memory  addressing.  Ihe  instruction  set  shall  use  16-bit  logical  addresses  to  provide  for  referencing  of  65,536 
words.  When  the  expanded  mentory  option  (see  paragraph  4.5.2)  is  not  implemented,  physical  addresses  shall  equal 
logical  addresses. 

4.5. 1.1  Memory  addressing  arithmetic.  Arithmetic  performed  on  memory  logical  addresses  shall  be  modulo 
65,536  such  tlrat  references  to  tlic  maxitnum  logical  address  of  I  'l  'Fl'K,  plus  1  shall  be  to  logical  address  OOOOi^. 

4.5. 1.2  Memory  addressing  boundary  constraints.  There  shall  be  no  odd  or  even  memory  address  boundary 
constraints. 

4.5.2  Kxpanded  inemorv  addressing  (optional).  If  used,  then  expanded  memory  addressing  shall  be  performed  via 
a  memory  paging  scheme  its  depicted  in  figure  1.  Ihcrc  sliali  be  a  maximum  of  512  page  registers  in  the  page  file 
(not  in  logical  memoo'  space),  'llicsc  shall  functionally  be  partitioned  into  16  groups  witli  2  sets  per  group  and  16 
page  registers  per  set.  Witliin  a  group,  one  set  shall  be  designated  for  instruction  references  and  tire  other  set  for 
operand  references.  Ihc  page  size  shtill  be  4096  words  such  that  one  set  of  16  page  registers  shall  be  capable  of 
mapping  65,536  words  defined  by  a  16-bit  logical  address.  The  page  group  shall  be  selected  by  the  4-bit  Address 
State  (AS)  field  of  the  Status  Word  (SW).  'Ihc  insmiction/operand  set  within  tire  group  shall  be  selected  by  the 
hardw  are  that  differentiates  between  instruction  and  operand  memory  references.  Ihe  4  most  significant  bits  of  any 
16-bit  logical  address  shall  select  tire  page  register  witliin  that  set.  Ihe  8-bit  Physical  Page  Address  (PPA)  within  the 
page  register  shall  be  concatenated  with  the  12  least  significant  bits  of  the  logical  address  to  form  a  20-bit  physical 
address,  allowing  addressing  of  1,048,576  words  of  physical  memory. 

4.5.2. 1  Group  selection.  During  instruction  and  operand  references  to  memory,  the  address  state  (AS)  field  of  the 
status  word  shall  be  used  to  designate  the  page  file  group.  During  an  interrupt  recognition  sequence,  the  operand  set 
of  group  zero  shall  be  used  for  vector  table  and  pointer  references  to  memory. 

4. 5.2.2  Pace  register  word  format.  Kach  page  register  shall  be  16  bits.  The  figure  below  indicates  tire  format  for 
the  page  register  words  with  the  following  paragraphs  describing  tire  meaning  of  the  access  lock  (AL)  field,  the 
execute  protect  (H)  bit,  the  write  protect  (W)  bit,  reserved  bits,  and  the  Physical  Page  Address  (PPA)  field. 


AL  I  E/W|  Reserved  |  PPA 


0  3  4  6  7  8  15 

Al.  Field:  The  access  lock  and  key  feature  is  optional  if  expanded  memory  addressing  is  implemented.  If 

the  access  lock  and  key  feature  is  not  implemented,  then  the  Al .  field  shall  always  be  zero.  If  it  is 
implemented,  then  a  4-bit  field  (bits  0  through  3)  of  each  page  register  shall  contain  the  access 
lock  (AL)  code  for  the  asstKiated  page  register,  which  shall  be  used  with  the  access  key  codes  to 
determine  access  permission.  Ihc  access  key  codes  may  be  supplied  by  cither  the  status  word  or 
the  DMA  channel.  For  each  of  the  possible  16  values  of  the  Al .  code,  access  shall  be  permitted 
for  the  reference  acc  'rding  to  table  VII. 

References  supplyin?  *  i  unacceptable  access  key  code  shall  not  modify  any  memory  location  or 
general  registers  and  .m  access  fault  shall  he  generated.  An  ;icccss  fault  resulting  from  a  CPU 
reference  attempt  shall  set  fault  register  bit  0  to  cause  a  machine  error  interrupt.  An  access  fault 
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H  Bit; 


W  Bill 


Reserved  Bits; 


I  Alii  I-  \  II.  \l  I  lid  •  li'  ■■■,  '■  .■>  III.IPIIUII' 

Al,  Code  Accept  a  b  J  A  c  c  ess  Ki  ;_y_  Codes 


0 

1 

2 

3 

4 

5 

6 

7 

8 
0 
A 
B 
C 
0 
E 
F 


0 


0. 1 .2.3.4 


0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 


1 

2 

3 

4 

5 

6 

7 

8 
0 
A 
B 
C 
0 
E 

8,9.A,B,C,D,E.F 


resulting  from  a  OMA  attempt  slvill  set  fault  register  hit  1  to  e.iuse  a  mach  ne  error  interrupt. 

Note  that  the  access  kxik  and  key  codes  defined  in  the  above  table  have  the  following 
characteristics' 

a.  An  access  lock  code  of  is  an  "unlocked"  lock  code  and  allows  any  and  all  access 
key  codes  to  be  acceptable. 

b. An  access  key  code  of  0  is  a  "master"  key  code  and  is  acceptable  to  any  and  all  xccss 
lock  codes. 

c  Access  key  codes  I  through  !-|(,  are  xceptablc  to  only  their  own  "matched"  lock  code 
or  the  "unlcKkcd"  lock  code  of  Fjj. 

d.An  access  key  code  of  is  acceptable  to  only  the  "unlocked"  lock  code  of  Fjj. 

l  or  instruction  p.igc  register  sets  only,  bit  4  shall  be  defined  as  the  1-1  bit  and  shall  determine  the 
acceptable/unacccptabic  criteria  for  read  references  for  instruction  fetches.  When  Fl=  1.  any 
attempted  instruction  read  reference  designating  that  associated  page  register  shall  be  terminated 
and  an  execute  protect  fault  ...all  be  generated.  An  execute  protect  fault  shall  set  fault  register  bit 
0  to  cause  a  machine  error  internipt. 

l  or  operand  page  registers  only,  bit  4  shall  he  defined  as  the  W  bit  and  shall  dctcnninc  the 
acccptable/un.acccptable  criteria  for  write  references.  When  W=  1.  any  attempted  write  reference 
designating  that  associated  page  register  shall  not  modify  any  memory  location  and  a  write  protect 
fault  shall  be  generated.  A  write  protect  fault  resulting  from  a  Cl'U  reference  attempt  shall  set 
f.uilt  register  bit  0  to  cause  a  machine  error  interrupt.  A  write  protect  fault  resulting  from  a  DMA 
reference  attempt  shall  set  fault  register  bit  1  to  cause  a  machine  error  interrupt. 

Bits  5  through  7  of  all  of  the  page  registers  shall  be  reserved  and  shall  always  be  0. 
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I’l’A  1  K  Ki:  All  i.'i;j'iU  hil  tkij  (l>ils  S  [linniyh  IS)  urc.ich  p.ij'o  rciiistor  sIkiII  he  dcdic,iU\l  lu  the  pin  vie.  i!  p.i.i;e 

■idilrev.  V,  hii  ii  is  used  Id  deliiie  llie  pip. sieul  .iddiess  .r.  dt  pit  led  in  tijuiie  I . 

4  S. 2. 1  I’  ll  II  il  minleiiie'il.iiidiis  dI  espuiuled  iiienijn\_.iddii--^ii^.  A  ;jden  ii iipleiiieiu.il loii  (>'  tins  suind.ii d  m.iv 
UK  hide  .1  p  II  li.il  miplement.ilii.n  ul  llie  exp.nided  .ividres  .|iie  opliiiii.  I  h.il  piirli.il  iinpleiiieiil  il  ic  i  in.u  lu.  .A  4,  i>r  S 
eieup.i'l  p.i.  e  leeislei's  ,is  liilKn'.s; 

Nunibu i;  of  Groups  AS  Grout)  Codes 

2  0  a  n  d  1 

•1  OlhroughO 

8  0  through  7 

Within  'll.  lull  III  p.mi.il  inipleiiient.iiidiK  ihe  Inek  le.iUiiv  in.ii  oi  in,i>  mil  he  iiieliidcd. 

'  ^  ji.  .HdliL;  J.'-T'J'_>n.ilJ.  If  used.  Ihon  hit  2  in  llv-  I'.iull  re'gister  sh.ill  he  set  in  iiKli...:ie  :  I'leiiU'i'.  truUy 

eimr 

'Sid'  '1 1.  hliH  k  pinK’i  !  (I'liiion.il).  If  used,  sh.ill  he  is  dcserihcd  hy  the  iiipui/diilpni  iiistnu-tuins,  h'lir 
I'pe:  .ilh  i' !'  u  hii.  ii  i  mu.  tin  iiuilliple  iiicmor.  re  fere  nee's,  e.ieh  store  oi'ieralioii  sh.ill  he  as  delii.sd  hy  the  iiieniiiry 
proiet  umi  Im  ih.il  spetilie  nieiiiory  .iddress. 

4  S  S  Uei’ereni  es  to  uniinpleiueiued  iiiemors.  Auengned  .leeess  ti'  phvsie.il  .iddressos  whieh  arc  lu'l  iinpknieiucd 
sh.ill  eenei.ite  .in  illec.il  .iddiess  l.niU  .ind  sh.ill  e.iuse  ihe  leleicneing  .Ktion  ui  leniuii.iie.  \n  illegal  , iddress  fault 
sh.ill  set  1.1. ill  leuisior  hii  S  lo  e.iuse  .i  ui.iclune  error  internipt. 

4  S.h  S'. 'l  l  nil  ROM  ((iiMiiin,il).  If  used,  the  si.iri  up  read  only  memory  (ROM)  address  lanee  shall  he  eoniiguous 
siaitiiii;  triiiii  .iddiess  I)  up  lo  .i  m.ieimimi  of  hS.SVi.  as  reguiied  hy  the  sysiem  .ipplic.iiioii  When  ihe  si.ui  ig)  ROM 
IS  eiuihl.'d.  il  an  I/O  or  Cl’l.l  stoic  funeiion  is  exeeiitcd  whose  address  is  within  the  M.iri  up  ROM  ihen  ihe  store  is 
.lUeinpied  inio  ihe  main  ineinory.  W  hen  the  si.iri  up  R{A1  is  enabled,  if  .i  re, id  function  (iiisiniciitiii  or  oper.iiid)  is 
exeeuied  li'oni  eilher  I/O  or  the  C  I’L  whose  .iddress  is  to  die  si.irt  up  ROM.  ihen  the  read  sh.ill  be  from  ihe  sitiii  up 
ROM.  W  hen  disabled,  the  start  up  RO.M  e.innot  be  .leecsseil. 

^  Riser. ed  memorx  loe.ilions.  1  .oe.iiions  2  thrmigh  ll'i^ arc  rcserred.  I  oeaiions  20|^  throuch  M-  ,  are  used 
by  lire  h.ndw  .ire  .iiid  the  siored  program  as  delined  by  table  VIII. 

4.fi  Iniei  I  urt  eoiitrol. 

4  h.l  liiiei  runts.  1410  instnietion  set  shall  support  a  mmimum  of  sixteen  (lb)  interrupts  .is  shown  in  i.ihle  \  III.  An 
nuerrupi  regiiest  niav  oeeiir  at  any  t'me;  however,  the  interrupt  processing  must  wail  until  the  turrem  iiisii  iiLiion  is 
-ompleied  .\n  e.xeepiion  to  this  is  the  Move  Multiple  W'ord  which  m.iy  he  interrupted  .ifiei  e.ieh  single  word 
ir.insfer.  I  ho  ovei.ill  procedure  for  .iceept.inee  of.  responding  to.  and  priKcssing  of  an  internipt  shall  be  .is 
illiisii.ited  hy  the  How  eh.irt  of  figure  2. 

4  h.l. I  liiternint  accent.iiicc.  Ihe  interrupt  svstcin  shall  have  the  capability  to  .icccpi  exiein.il  .ind  I'liernal 
iiilernipis.  higure  2  indicates  the  relationship  hetween  the  intemipt  sigii.ils.  the  pending  inieiriipi  u-gi  .'.m.  the 
nlsiiiipl  lii.isk  register,  die  priority  control  logic,  the  software  controll.ible/accessihle  signals  ,md  ihc  '  ind.irnent  il 
I  oinniunic.itions  hetween  the  interrupt  svstein  and  the  CPU. 

Wi.  1 Ini  ' Tupt  sofiw.ire  cmiirol.  Software  sh.iM  he  ahle  to  input  from  or  output  to  ihe  inU'i  nipi  -n.isk  lei  isici  .is 
sail  .!'■  the  iKiulme  inlmriip!  iee.i-!ei.  Also,  sollw.iie  sh.iii  I'e  ,ihle  lo  dis.!ll,iw  ici. ognilioii  ol  inu  loipls  i  i.i  die 
1'  -  '  I.'  iru  ’  I  iipi . "  sii'.ii.!l  ('.Mlhoiil  nihihiliii"  miei  rupl  .Kcepi.im  e  iiilo  die  pel  nil  ii.c  nui  nipt  regisu'i  I  iiul  lo  all,  iw 
.  <  '  :. ilim .  ot  ii.l  'ii  iipts  \  1.1  ihe  ""ii.ihl.'  iiitei  iiipis"  si.'ii.il.  I  he  disablin'.'  sh.  'l  i.ol  .iPow  'iu  mle  .gus  .u k  I  die 
d  r, n  lie  .'  die  dis.ihli’  'ii-.i i ik  ;it .u  .  'i.'  t  R'  s  a  |.,  : ;  iii>l  s.n  \  kc  Ikii dw .n e  .. onl i niie  :  '  s  '"'er'  ’iMs  '  d  T 

-  "S'  ''I'll  I " 'll  .lit.  r  die  i  a  la  II  ga  ,  I:'."':..  ■ ..  .  ■  .  c.iindeled  ("il'.l,  ' -pli.  '  1 1-  .  i '  a  .  -e  ..>s|  i  u.  I  ions 
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1  Alll  1'  VIII.  iMicrmiH  dcliniliuns 


I  n  torrup t 
Number 

1 

1  Interrupt 
1  Mask 

1  Bit 

1  Number 

1  Interrupt 

1  Linkage 

1  Pointer 

1  Address 

1 

1  Interrupt 

1  Service 

1  Pointer 

1  Address 

1  (Hex) 

1 

1 

I 

0 

1  0 

1 

1 

1  20 

1 

1 

1  21 

1 

1 

1  Power  Down  (cannot  be  masked 

1  or  disabled) 

1 

1  1 

1 

1 

1  22 

1 

1 

1 

1  23 

1 

i 

1  Machine  Error  (cannot  be 

1  disabled) 

2 

1  2 

1 

1  24 

1 

1  25 

1 

1 

1  Spare 

3 

1  3 

1  26 

1  27 

1  Floating  Point  Overflow 

4 

I 

1  4 

1 

1  28 

1 

1  29 

1  fixed  Point  Overflow 

5 

I 

1  5 

1 

i 

1  2A 

1 

1 

1 

1  28 

1 

1 

1  Executive  Call  (cannot  be 

1  masked  or  disabled) 

6 

I  3 

1  2C 

1  20 

1  Floating  Point  Underflow 

7 

1 

1  7 

1 

1 

1  2E 

1 

1 

1  2F 

1 

1  Timer  A  (if  implemented) 

8 

1 

1  B 

1  30 

1  31 

1  Spare 

9 

1 

1  9 

1 

1 

1  32 

1 

1 

1  33 

I 

1  Timer  B  (if  implemented) 

10 

i  10 

1  34 

1 

1  35 

1  Spare 

11 

1 

1  11 

1 

\ 

1  36 

1 

1 

1  37 

1 

1  Spare 

12 

1  12 

1 

1 

1  38 

1 

1 

1  39 

1 

1 

1  Input/Output  Level  1 

1  (if  implemented) 

13 

1  13 

1 

1  3A 

1 

1  38 

1  Spare 

14 

1  14 

1 

1 

1  3C 

1 

1 

1 

i  3C 

1 

1 

1  Input/Output  Level  2 

1  (if  implemented) 

15 

1  1& 

1  3E 

1  3r 

1  Spare 

Notes : 

Interrupt 

number  0  has 

the  highest 

priority.  Priority  decreases 

with  increasing  interrupt  number. 
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.lie  ^i\en  in  ilic  iiipui/iniipiii  msiiin  non  rcpcrioia-. 

4  6. 1  .,T  liiioi  Mini  pi  II  'riiv  detMiiliims.  I  he  priciriiy  cicllnitioiis  nl'ilic  inU'rrupts  .ind  thoii  required  lelalionship  to 
the  intenupi  in.r.i,  uul  iiiterriipi  p(iinter.Kl(Jressesare  illiisii.Ked  in  i.ilric  \  III.  Inlemipi  Definiiions,  ITic  power 
doA  n  intorni[U  sli.ill  initi.iie  ilie  power  down  sequeneo  and  cannot  he  masked  or  dis.ihled  dining  nonnal  operation 
of  the  eoinpiitei  I  he  exeemivee.ill  inli'irupt.  used  '.litli  the  Hraiich  to  l^xceuInc  msiniciion,  Bl-X,  (sec  page  62)  also 
cannot  he  masked  or  disabled.  I  he  m.iehinc  error  interrupt  cannot  he  disabled  but  can  be  masked  during  normal 
operation  of  the  eomputcr.  All  other  interiiipisc.in  be  disabled  and  masked.  Ifa  Moating  point  overflow/underdow 
oi  fixed  point  o\ei  Mow  condition  occurs,  then  the  instruction  generating  tliat  condition  shall  be  intcniiptcd  at  its 
completion  if  the  interrupt  is  unmasked  and  enabled. 


4.6  1. 4  inieriiii't  leetonne  nicehanism.  Ilie  vectoring  mechanism  shall  be  as  illustrated  on  figure  3.  Koreach 
mteiTupt  there  sh.ill  lie  two  fixed  mcmoiv  loc.itions  in  the  "vector  table";  (I)  the  first  memory  IfKiition  (I  inkage 
I’oi  liter)  shall  he  defin -d  as  the  address  ol  where  to  store  the  current  (old)  state  of  the  computer  (i.c.,  "old  intcirupt 
rn.isk"  "old  st.itus  word",  and  "old  instruction  counter");  and  (2)  the  second  memory  location  (Service  Pointer)  slinll 
he  defined  as  the  address  ol  the  next  (new)  state  of  the  computci  (i.c.,  “new  interrupt  mask",  "new  status  word",  and 


"new  instruction  counter").  Kcttii  ning  from  interrupts  may  be  accomplished 

(l.Sl/I.Sl  1)  instruction  with  the  valuc/addrcss  of  the  l.inkagc  Pointer  for  an 

Interrupt  0-->| 

Linkage 

— 

->| 

Old  Interrupt 

1 

1 

Pointer 

0  1 

1 

Mask 

1 

1 

Service 

— 

1 

Old  Status 

1 

1 

Pointer 

0  1 

1 

1 

Word 

1 

Interrupt  l-->i 

Linkage 

1 

1 

I 

Old  Instroc. 

1 

1 

Pointer 

1  1 

1 

1 

Counter 

1 

1 

Service 

1 

1 

1 

Pointer 

1  1 

1 

1 
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Mask 

1 

Interrupt  15->| 

Linkage 

1 

1 

New  Status 

1 

1 

Pointer 

15| 

1 

Word 

1 

1 

Serv ice 

1 

1 

New  Instruc. 

1 

1 

Pointer 

15| 

1 

Counter 

1 

\  Computer 
>  status  at 
/  the  time  of 
/  interrupt 


\  Computer 
>  status  to 
/  start  service 
/  routine 


FIGURK  3.  Interrupt  vectoring  system 


4.7  InDut/oiitniit.  In  conjunction  with  the  spare  command  codes,  the  I/O  interrupts,  and  the  I/O  interrupt  code 
registers,  the  I/O  instructions  provide  a  framework  vviiliin  which  the  user  c.nn  implement  his  system  interfaces.  The 
particulars  of  the  system  interfaces  outside  of  this  framework  (such  as  dedicated  memory  locations,  channel  register 
definitions,  comm.md  code  assignmcnts/dcfiniiions.  multiple  channel  priorities,  page  register  access,  etc.)  are  not 
included  in  this  standard. 
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4.7.1  Input.  Itic  input  iiisiiuctiuns  transfer  data  from  an  c.xtcrnal  I/O  device  or  an  internal  special  register  to  a 
t'Pf  !  general  register,  litis  coimnand  is  used  to  read  data  from  peripheral  devices,  tuners,  si.itus  word,  i.uilt  icgistcr, 
discretes,  interrupt  mask,  etc,  A  full  description  of  die  input  instructions  is  given  in  die  instruction  repeitoire. 

4.7.2  Output.  The  output  instructions  tninsfer  data  from  a  CPU  general  register  to  an  cviei  ual  I/O  dev  ice  or 
special  register.  Iliis  command  is  used  to  write  data  to  peripheral  devices,  discretes,  start  and  stop  tinicrs,  enable  and 
disable  interrupts  and  DMA,  set  and  clear  interrupt  requests,  masks  and  pending  interrupt  bits,  etc.  A  full 
description  of  the  output  instructions  is  given  in  the  instaiction  repertoire. 

4.7.3  Innul/ouiput  comm.inds.  (nput/oiitpui  commands  are  classified  as  mandatory,  optional,  reserved,  or  spare. 
Mandatory  I/O  commands  must  he  implemented  as  defined.  Optional  I/O  commands  must  be  implemented  as 
defined,  if  implemented.  Reserved  I/O  commands  must  mil  be  implcnicntcd.  Sparc  I/O  commands  may  be 
implemented  as  required  hv  the  application.  Attempted  execution  of  an  iinimplcnicntcd  optional  or  spare  I,  O 
command  or  a  reserved  I/O  command  shall  cause  tlic  illegal  I/O  command  fault  to  be  set  in  the  fault  rcgistei  (I'l  5) 
causing  a  machine  error  intci nipt.  Input/output  command  words  shall  be  fully  decoded.  "  I'lJOs"  m  inpui/output 
instruction  descriptions  refer  to  p.iranictcrs  to  be  determined  by  die  application  system  requirements.  Within  these 
classifications,  die  use  of  the  command  is  defined  in  the  instruction  description. 

4.7.4  Innut/outnut  command  partitioning,  'llic  I/O  command  space  shall  be  divided  into  128  channels.  Up  to 
512  coinmaiuls  within  each  channel  group  (256  input  and  256  output)  may  be  used  with  each  I/O  interface,  fable 
IX  lists  the  128  I/O  channel  groups.  I  he  attempted  execution  of  an  unimplcincnied  I/O  command  shall  cause  bit  5 
of  the  fault  rcgisicr  to  be  set,  generate  a  machine  error  interrupt,  and  abort  to  completion. 

4.7.5  liiDut/outoLit  intci  runts  (optionaM.  Input/output  level  1  and  level  2  interrupts  arc  available  to  the  user. 
Kithcr  intcrnipt  level  or  both  may  be  implemented  for  an  interface  as  defined  by  tlic  particular  application 
specification.  Ihc  internipts  shall  be  used  in  conjunction  with  tlic  input/output  intcrnipt  code  registers  to  provide 
I/O  channel  to  process  communications.  Two  levels  of  interrupts  allow  easy  differentiation  of  normal  reporting 
from  error  reporting. 

4.7.6  Dedicated  I/O  nicmorv  locations.  If  dedicated  memory  locations  arc  used  to  communicate  information  to 
and/or  from  an  I/O  channel,  these  locations  shall  be  consecutive  memory  locations  starting  at  an  implementation 
defined  location.  Ixx;ations40|^  tlirough  4Kjj  arc  optional  for  I/O  usage. 

4,8  Instnictions. 

4.8. 1  Invalid  instmetions.  Attempted  execution  of  an  instruction  whose  first  16  bits  are  not  defined  by  this 
standard  sliall  cause  the  invalid  instruction  bit  in  the  fault  register  (FT^)  to  be  set  generating  a  machine  error 
intcrnipt.  All  undefined  bit  patterns  in  the  first  16  bits  of  an  instruction  arc  reserved. 

4.8.2  Mnemonic  conventions.  Rach  insiniction  has  an  assiKiatcd  mnemonic  convention.  In  general,  the  operation 
is  one  or  two  letters,  c.g.,  1.  for  load,  A  for  add,  ST  for  store. 

Floating  point  operations  have  a  prefix  of  F.  e.g.,  FI,  for  floating  load,  FA  for  floating  add. 

Double  precision  operations  have  a  prefix  of  D,  c.g..  Dl.  for  double  load,  DA  for  double  add. 

Hxtended  precision  floating  point  operations  have  a  prefix  of  HF,  e.g.,  FF'A  for  Extended  precision  floating  point 
add. 

Rcgistcr-to-registcr  operations  have  a  suffix  of  U,  c.g..  AR  for  single  precision  add  icgistcr-to-rcgistcr,  FAR  for 
floating  add  rcgistcr-to-registcr. 

Indirect  memory  reference  is  indicated  by  a  suffix  I.  c.g..  1.1  for  load  indirect. 

Immediate  addressing,  using  the  address  field  as  an  operand.  Is  indicated  by  a  suffix  of  IM,  e  g..  MM  for  single 
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lAltl  |  -  IX.  Iiipiii/uiiipiii  ili.iiiiu'l  groups 


Outp.Ul 

Inout 

Usage 

ooxx 

80XX  \ 

> 

PIO 

03XX 

83XX  / 

04XX 

e4XX  \ 

> 

Spare 

IFXX 

9FXX  / 

20XX 

AOXX 

Processor  &  Auxiliary  Register 

Control 

21XX 

AIXX  \ 

> 

Reserved 

2FXX 

AFXX  / 

30XX 

BOXX  \ 

) 

Spare 

3FXX 

BFXX  / 

40XX 

COXX 

Processor  8f  Auxiliary  Register 

Control 

41XX 

CIXX  \ 

> 

Reserved 

4FXX 

CFXX  / 

50XX 

OOXX 

Memory  Protect  RAM 

SIXX 

DIXX  \ 

> 

Memory  Address  Extension 

52XX 

D2XX  / 

(page  register  commands) 

53XX 

D3XX  \ 

> 

Spare 

7FXX 

FFXX  / 

precision  add  immediate. 

Use  of  indexing  is  specified  in  assembly  language  by  the  occurrence  of  the  operational  field  after  the  address  field, 
e.g.,  FA  A2,ALPHA,A5:  floating  add  to  register  A2  from  memory  location  ALPHA  indexed  by  register  A5. 

4.8.3  Instruction  matrix.  Table  X  contains  the  order  type  matrix  which  relates  each  instruction  operation  code  to 
an  assigned  symbol.  Ibc  numbers  shown  across  the  top  of  the  matrix  are  hexadecimal  numbers  which  represent  the 
higher  order  four  bits  of  the  operation  code,  and  tlic  hexadecimal  numbers  along  the  left  side  represent  tlie  lower 
order  four  bits  of  the  operation  ettde.  Table  XI  contains  tlic  order  types  and  assigned  mnemonics  for  the  extended 
Operation  Code  instnictions. 

4.8.4  Instruction  set  notation.  The  text  and  register  transfer  descriptions  arc  intended  to  complement  each  other. 
Ambiguities  or  omissions  in  one  arc  resolved  by  the  otlicr.  Ihc  following  definitions  and  special  symbols  are 
associated  with  the  instruction  descriptions. 
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(■  I’ll  Ka'ists'XS 

KO.  Rl,  R15  The  16,  16-hit  goncr.tl  rogisiets 

IC  Instmtiion  Counter 

SW  Stilus  ^V'ord 

CS  Coii<Jiti<‘;i  Stjtus.  A  4  hn  tjo.iniiiy  ih.ii  is  sci  .iccording  to  ilie  ii'so’;  of  idsiuk  iioii  exeLU.oons. 

I  P  1  inkuge  Pointer 

SP  Suck  Pointer;  R15  for  the  I’ush  anil  Pop  VUiliiple  instructions 

SVP  Service  Pointer 


B,  BX  Base  Relative.  Base  Relative  with  Indexing 

S  Special 

Data  OuanCiCics 

MSM.  LSH  Most  Sigiiificant  Half,  I  cast  Significant  1  lalf 
MSB, !  SB  Most  Significant  Bit,  Ixiast  Significant  Bit 

S.P.  D.P.,  Ft.  P.,  E.F.P. 

Abbreviation  for  "Single  I'rccision."  "Double  Precision,"  "Floating  Point,"  and  "Extended 
Floating  Point"  operations,  respectively. 

Floating  Point  Derived  Operand  mantissa  (fraction.il  part):  IX)q  j(  (•'*  1^0  n  *^^32  17 

(F:.F,P.) 
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1  1  )  I  u:  l  "!!'!  S  hil  Mullipk-ii.i'ii'  !  <  )]'■  ih.ii.u  i.  i  IMIL  li.  »p<)ticnt)'  1  X)24. 31 

M.\ 

I  !>'  iiiri".  (Miiii  I'j  ,n  fill  hill  ill  ir  in.inlivsa  (fi.n  tum.il  pan).  <I<A.KA  :  !  )„  >^  ( I  l  I’ ).  {KA.KA  -I  I )(, ; )  (RA  + 

!  n 

I  A  1  liKUing  pi  mu  S  bii  .lA  rompK'nii'ui  ivgistci  amimul.iiur  iliai.icu  i  i^iic  (exponent): 

(KA  KA  4  l)/.i  11 

Ml’.  M(J  \n  enniv  iisi  J  lor  register  level  M,ln^^er  lieM-iiptum  elarificalion.  lliesc  registers  are  not  part  of 
the  gencr.,1  logistei  file. 


■Miuel'aneous 


(X) 

(X  X  4  I) 
[X'l 

IX  X-,  !] 
OVM 
Ivxii 
IM 


( 'ontciiLs  111  Register  X 

(  oiuciits  o(  concatenated  Registers  X  and  X  +  1 
Tontents  nl  inciiiory  address  X 

Contents  of  icqucniial  memory  locations  X  and  X  4  1 
Mantissa  (fiactioiial  part)  overflow 

Indicates  termination  of  present  register  transfer  ('perauon  (except  the  setting  of  Uie  CS  bits) 
Derived  Address 


DO 

N.  M,  n 
DSPl. 


X' 


Symbols 

<-• 

< --> 


X 


Derived  Operand 
An  integer  mimber 
Displacement 

If  X  IS  a  CPU  register  or  a  data  qu.iniity  (sec  above),  then  n  specifies  a  bit  position  in  X.  If  X  is 
not  a  CPU  register  or  a  data  quaniilv.  then  the  number  X  is  to  the  base  n.  If  X  is  a  number  and 
n  -- 16.  then  X  is  a  2's  complement  hexadecimal  number. 

If  X  IS  .1  CPU  register  or  a  mcinoiy  address,  then  i  specifics  the  state  of  X  ITiis  notation  is  used  in 
die  register  tiansfer  descriptions  10  rilcr  to  the  contents  of  a  CPU  register  or  a  memory  address  at 
different  times  (suites)  t)f  the  execution  of  Uic  instruction.  If  X  is  not  a  CPU  register  or  a  memory 
address,  then  Uic  number  X  is  raised  to  the  iih  power. 


Unilateral  transfer  designator 
Ihlatcral  transfer  designator 
Comparison  Designator 

Indicates  a  "don't  care"  bit  when  used  in  a  binary  number 
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> 

I  ,css  than 


> 

< 

t 


II 


Greater  than 

< 

Hejuals 

Greater  than  or  equal 
I  x;ss  than  or  equal 
Logieal  AND 
Logieal  OR 
Hxclusivc  OR 
l-OgicalNOT 
Absolute  value 
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S  1)1  l  Ali  I  DKI  OUIUI  MI  NIS 


5 . 1  I  i n |) u  1  / I'UlUUl. 

AnOR  MODt  MNF.MONtC 

IM  XIO  RA.CMO 

IMX  XIO  RA.CMO.RX 


lOHHAT/OPCOOE 

8  4  4  16 


I  48  I  RA  I  RX  I  I  CMD 


OI  'SCKII' MON:  llie  input/uutput  instruction  transfers  data  between  an  exiernal/internai  device  and  the  register 
RA.  Ihe  1  )erived  Operand,  IX).  specifies  the  operation  to  be  performed  or  the  device  to  be 
addressed.  Ihc  immediate  operand  field  may  be  viewed  as  an  operation  code  extension  field. 
Note  that  if  indexing  is  specified,  then  die  inpui/ouipiit  operation  or  device  address  is  fonned  by 
summing  the  contents  of  the  register  RX  and  the  immediate  field.  I'his  is  a  privileged  instruction. 

ITie  mandatory  and  optional  input/output  immediate  command  fields  are  listed  below. 

Mandatory  XIO  Command  I'ields  and  Mnemonics 


OYXX  PO  Programmed  Output:  'Ihis  command  outputs  16  bits  of  data  from  RA  to  a  programmed  I/O  port. 

Y  may  be  from  0  through  3. 

2000  SMK  Set  Internipt  Mask:  Ihis  command  outputs  the  16-hit  contents  of  the  register  RA  to  the  interrupt 

mask  register.  A  "1"  in  the  corresponding  bit  position  allows  the  interrupt  to  occur  and  a  "0" 
prevents  the  interrupt  from  occurring  except  for  tliose  interrupts  Uiat  arc  defined  such  that  they 
cannot  be  masked. 


2001  CI.IR 

2002  t:NBI 

2003  DSUl. 

2004  RPl 


Clear  Interrupt  Request;  All  internipts  arc  cleared  (i.e..  the  pending  interrupt  register  is  cleared 
to  all  zeros)  and  the  contents  of  the  fault  register  arc  reset  to  itero. 

Hnablc  Interrupts;  This  command  enables  all  interrupts  which  arc  not  masked  out.  Ihe  enable 
operation  uikes  place  after  execution  of  the  next  instruction. 

I  )isablc  Intcraipts:  This  command  disables  all  interrupts  (except  those  that  arc  defined  such  that 
they  cannot  be  disabled)  at  the  beginning  of  the  execution  of  the  DSBI.  instruction. 

Reset  Pending  Internipt;  Ihc  individual  interrupt  bit  to  be  reset  shall  be  designated  in  register 
RA  as  a  right  justified  four  bit  code.  (0|g  represents  interrupt  number  0,  represents  interrupt 
number  15).  If  interrupt  1 is  to  be  cleared,  then  the  contents  of  the  fault  register  shall  also  be  set 
to  zero. 


2005  SPI 


200K  WSW 
8YXX  PI 


Set  Pending  Interrupt  Register;  Ihis  command  outputs  the  16-bit  contents  of  RA  to  the  pending 
interrupt  register.  If  there  is  a  one  in  the  corresponding  bit  position  of  the  interrupt  mask  (same 
bit  set  in  both  the  PI  and  tlic  MK).  and  the  interrupts  arc  enabled,  then  an  interrupt  shall  occur 
after  execution  of  the  next  instruction.  If  PI5  is  set  to  1,  then  N  is  assumed  to  be  0  (see  paragraph 
5.30). 

Write  Sutus  Word:  Ihis  command  transfers  the  contents  of  RA  to  the  status  word. 

Programmed  Input:  This  command  inputs  16  bits  of  data  into  RA  from  the  programmed  I/O 
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port.  Y  may  be  from  0  through  3. 

.'\000  RMK  Read  Interrupt  Mask:  Ihe  current  interrupt  mask  is  transfered  into  register  RA.  Ihc  interrupt 
mask  is  not  altered. 


A004  RPIR  Read  Pending  Interrupt  Register:  This  command  transfers  the  contents  of  the  pending  interrupt 
register  into  RA,  Ihe  pending  interrupt  register  is  not  altered. 

AOOi;  RSW  Read  Status  Word:  'Ihis command  transfers  the  16-bit  status  word  into  register  RA.  I  hc  status 
word  remains  unchanged. 

AOOl  '  RCFR  Read  and  Clear  Fault  Register:  Ihis  command  inputs  the  16-bit  fault  register  to  register  R  \. 

Ihc  contents  of  the  fault  register  arc  reset  to  zero.  Hit  1  in  the  pending  interrupt  legistcr  is  reset  to 
zero. 


Ootitmal  XIO  Command  Fields  and  Mnemonics 


2008  OD  Output  Discretes:  This  command  outputs  the  16-bit  contents  of  the  register  RA  to  the  discrete 

output  buffer.  A  "1"  indicates  an  "on"  condition  and  a  "0"  indicates  an  "off'  condition. 

200A  RNS  Reset  Normal  Power  Up  Discrete;  This  command  resets  the  normal  power  up  di-.cicte  bit. 

4000  CO  Console  Output;  Ihc  16-bit  contents  (2  bytes)  of  register  R  A  are  output  to  the  console.  Ihc  eight 

most  significant  hits  (byte)  arc  sent  first.  If  no  console  is  present,  then  this  command  is  treated  as 
a  NOP  (see  page  137). 


4001  CI.C 


Clear  Console;  This  command  clears  the  console  interface. 


4003  MPF.N 

4004  liSUR 

4005  DSUR 

4006  DMAE 

4007  DM  AD 

4008  TAS 

4009  TAH 


Memory  F-’rotcct  Enable;  Ihis  command  allows  the  memory  protect  RAM  to  control  memory 
protection. 

Knablc  Start  Up  ROM;  Ihis  command  enables  the  start  up  ROM  (i.e.,  the  ROM  overlays  main 
memory). 

Disable  Start  Up  ROM;  This  command  disables  tlic  start  up  ROM. 

Direct  Memory  Access  Enable;  'Ihis  command  enables  direct  memory  access  (DMA). 

Direct  Memory  Access  Disable;  Ihis  command  disables  DMA. 

Timer  A,  Start;  Ihis  command  starts  timer  A  from  its  current  state.  Ihe  timer  is  incremented 
every  10  microseconds. 

Timer  A,  Halt;  Ihis  command  halts  timer  •  t.'  ■.  nt  state. 


400A  O  TA  Output  Timer  A;  Ihc  contents  of  regisicj  .sA  are  loaded  (i.e.,  jam  transfered)  into  timer  A  and 
tlie  timer  automatically  starts  operation  by  incrementing  from  tlie  loaded  timer  in  steps  of  ten 
microseconds.  Hit  fifteen  is  the  least  significant  bit  and  shall  represent  ten  microseconds. 

40013  GO  ft  igger  Go  Indicator;  Ihis  command  restarts  a  counter  which  is  connected  to  a  discrete  output 

Ihe  peridri  of  time  from  restart  to  (ime-out  shall  beciciermined  by  the  system 
requirements.  When  tire  ('>o  timer  is  si:iried,  the  disc  rete  output  shall  go  high  and  remain  high  for 
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40<ji)  imi 
400I-:  01  n 

50XX  I  MP 


51XY  WIPR 

52XY  WOPR 

AOOl  RICl 

A002  RIC2 

A008  RDOR 

A009  RDI 

AOOBTPIO 

AOODRMFS 

COOOCl 
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I  III)  niilliscc()ii(J-i,  ill  i*hicli  tiiiio  iho  (iiiipiii  shiill  go  low  unless  uiiothci  CIO  is  executed,  llic  Go 
discrete  output  signal  inay  be  used  as  a  software  fault  indicator. 

I  imer  B,  Start:  1  his  command  starts  timer  B  from  its  current  state,  llie  timer  is  incremented 
every  100  microseconds. 

rimer  B,  Halt;  Ihis  command  halts  timer  B  at  its  current  state. 

Output  Timer  B;  'Ibe  contents  of  register  RA  are  loaded  (i.c.,  jam  transfered)  into  timer  B  and 
the  timer  automatically  starts  operation  by  incrementing  from  the  loaded  timer  in  steps  of  one 
hundred  microseconds.  Bit  fifteen  is  the  least  significant  bit  and  shall  represent  one  hundred 
microseconds. 

Load  Memory  Protect  RAM  (5000  +  RAM  address):  ITiis  command  outputs  the  16-bit  contents 
of  register  RA  to  the  memory  protect  RAM.  A  "1"  in  a  bit  provides  write  protection  and  a  “0"  in 
a  bit  permits  writing  to  die  corresponding  1024  word  memory  blcKk.  'Ilic  RAM  word  MSB  (bit  0) 
represents  the  lowest  number  block  and  the  RAM  word  LSB  (bit  15)  represents  die  highest  block 
(i.c..  bit  0  represents  locations  0  through  1023  and  bit  15  represents  locations  15360  through  16383 
for  word  zero).  Hach  word  represents  consecutive  16K  blocks  of  memory.  T3ic  RAM  words  of  0 
through  63  apply  to  processor  write  protect  and  words  64  dirough  127  apply  to  DMA  write 
protect 

Write  Instruction  Page  Register:  This  command  transfers  the  contents  of  register  RA  to  page 
register  Y  of  the  instruction  set  group  X. 

Write  Operand  Page  Register:  This  command  transfers  the  contents  of  register  RA  to  page 
register  Y  of  the  operand  set  of  group  X. 

Read  Input/Output  Interrupt  Code,  I^evel  1 :  This  command  inputs  the  contents  of  the  level  1 
lOIC  register  into  register  RA.  Ilie  channel  number  is  right  justified. 

Read  Input/Output  Interrupt  Code.  Ix:vel  2:  This  command  inputs  the  contents  of  the  level  2 
lOIC  register  into  register  RA.  The  channel  number  is  right  justified. 

Read  Discrete  Output  Register:  This  command  inputs  the  16-bit  discrete  output  buffer  into 
register  RA. 

Read  Discrete  Input:  This  command  inputs  the  16-bit  discrete  input  word  into  register  RA.  A 
"1"  indicates  an  "on"  condition  and  a  "0"  indicates  an  "ofT'  condition. 

Test  Programmed  Output;  This  command  inputs  the  16-bit  contents  of  the  programmed  output 
buffer  into  register  RA.  This  command  may  be  used  to  test  the  PIO  channel  by  means  of  a  wrap 
around  test. 

Read  Memory  Fault  Status;  This  command  transfers  the  16-bit  contents  of  the  memory  fault 
status  register  to  RA.  The  fields  within  the  memory  fault  status  register  shall  delineate  memory 
related  fault  types  and  shall  provide  the  page  register  designators  associated  with  the  designated 
fault 

Console  Input;  This  command  inputs  the  16-bits  (2  bytes)  (irom  the  console  into  register  RA. 

The  eight  most  significant  bits  of  RA  shall  represent  the  first  byte. 
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cool  RCS  Read  Console  Status;  I'his  command  inputs  the  console  interface  status  into  register  RA  llie 

status  is  right  jusiilied. 

COOA  ITA  Input  Timer  A:  'lliis  command  inputs  the  16-bit  contents  of  timer  A  into  register  RA.  Hit  fifteen 

is  the  least  significant  bit  and  represents  a  time  increment  of  ten  microseconds. 

COOK  TTB  Input  Timer  B;  'Ibis  command  inputs  the  16-bit  contents  of  timer  B  into  register  R  A.  Bit  fifteen 

is  the  least  significant  bit  and  represents  a  time  increment  of  one  hundred  microseconds. 

I'WXX  RMP  Read  Memory  Protect  RAM  (13000  +-  RAM  address):  Ibis  command  inputs  the  appropriate 

memory  protect  word  into  register  RA.  A  "1"  in  a  bit  provides  write  protection  and  a  "0"  in  a  bit 
pennits  writing  to  the  corresponding  1024  word  memory  bltK'k.  The  RAM  word  MSB  (bit  0) 
represents  the  lowest  number  block  and  die  RAM  word  LSI)  (bit  15)  represents  the  highest  block 
(i.e.,  bit  0  represents  loctitions  0  through  102.3  and  bit  IS  represents  locations  15360  through  16383 
for  word  zero),  t'ach  word  represents  consecutive  16K  blocks  of  memory.  Ibe  RAM  words  of  0 
Uirough  63  apply  to  processor  write  protect  and  words  64  through  127  apply  to  DMA  write 
protect. 

DIXY  RIPR  Read  Instruction  Page  Register:  "Ibis  command  transfers  the  16-bit  contents  of  the  page  register 
Y  of  tlic  instruction  set  of  group  X  to  register  RA. 

D2XY  ROPR  Read  Operand  Page  Register:  Ibis  command  transfer  the  16-bit  contents  of  page  register  Y  of 
the  operand  set  of  group  X  to  register  RA. 

••••  *•*«  defined  XIO  functions  (see  table  IX). 


Varies  depending  on  the  command  field. 


Varies  depending  on  the  command  field. 


XIO 
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'  -  \  ceU'i'-'J  iiuuii/uutnul 


ADDR  MODE 

MNEMONIC 

FOliMAf/OPCODE 

0 

VIO 

RA.ADDR 

6 

4  4 

16 

DX 

VIO 

RA.AOOR.RX 

1  49 

1  RA  1  RX  1  ! 

ADOR  1 

DI-.SCRIKHON:  llic  vectored  input/oulput  instruction  performs  the  I/O  opeiiUion  as  specified  by  the 
input/oiiiput  vector  Ubic  starting  at  the  derived  address.  DA.  as  shown  below: 


DA 

1  CMO 

1 

OA+1 

1  Vector  Select 

1 

OA+2 

1  Data 

1  } 

one  data  word  for  each  bit 

1 

set  in  the  vector  select 

Ihe  input/output  operation  or  device  address  is  specified  by  the  sum  of  the  CMD  and  the 
product  of  the  bit  number  of  the  bit  set  in  the  vector  select  times  the  contenis  of  RA.  This  device 
address  is  then  interpreted  as  specified  by  the  XIO  instruction  (sec  paragraph  5.1)  with  the 
exception  that  I/O  data  is  traiisfcred  to  or  from  IDA  +  2  +  i  rather  than  RA  (where  i  starts  at  zero 
and  is  incremented  after  each  transfer),  'ihis  is  a  privileged  instruction. 

REGISTER  TRANSFER  DESCRIPTION; 

Step  1.  n  <--  0  and  i  <--  0; 

Step  2.  if  [DA+l]n*l.  then  I/O  command  =  [DA]  +  {n  x  (RA)); 

Step  3.  if  [DA+I]„=1.  then  I/O  data  =  [OA+2+i); 

Step  4.  if  [OA+l]„=I,  then  i  <--  i+1; 

Step  5.  n  <--  n  +  1,  exit,  if  n  =  16; 

Step  6.  go  to  Step  2; 

REGISTERS  AFFECTED:  None 
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5.1  Sol  bit. 

^DR  MODE  MNEMONIC  FORMAT /OPCODE 


8 

4 

4 

SBR 

N.RB 

1  51 

1  N 

1  RB  1 

SB 

SB 

N.ADOR 

N.ADDR.RX 

8 

4 

4 

,  16 

1  50 

1  N 

1  RX  1  1 

ADDR  1 

8 

4 

4 

16 

SB  I 
SB  I 

N.ADOR 

N.ADDR.RX 

1  52 

1  N 

1  RX  1  1 

ADDR  1 

l')r.SCRIF*'riON:  Bit  number  N  of  the  IJcrived  Operand.  IJO,  is  set  to  one.  The  MSB  is  designated  bit  number  zero 
and  the  1. SB  is  designated  bit  number  fifleen. 

REGISTER  TRANSFER  DESCRIPTION: 

DO„  <--  1: 

REGISTERS  AEFECTEO:  R8 


SBR.SB.SBI 


T4 
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< 


5.4  Reset  hit. 


AODR  MODE 

MNEMONIC 

rORMAT/OPCODE 

8 

4 

4 

R 

RBR 

N.RB 

1  54 

1  N  1 

RB  1 

RB 

RB 

N.AODR 

N.ADOR.RX 

8 

4 

4 

16 

0 

DX 

1  53 

1  N  1 

RX  1  1 

ADOR  1 

8 

4 

4 

16 

I 

IX 

RBI 

RBI 

N.AODR 

N.ADOR.RX 

1  55 

1  N  1 

RX  1  1 

ADOR  1 

DRSCRIPnON:  Bit  number  N  of  the  Derived  Operand,  DO,  is  set  to  zero.  The  MSB  is  designated  bit  number  zero 
and  the  I,SB  is  designated  bit  number  fifteen. 

REGISTER  TRANSFER  DESCRIPTION; 

DO„  0; 

REGISTERS  AfEKUA:  RB 
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5.5  Tost  hit. 

AODR  MODE  MNEMONIC 


R  TBR  N.RB 


0  TB  N.AOOR 

DX  TB  N.ADDR.RX 


I  TBl  N.AODR 

IX  TBI  N.ADDR.RX 


rORMAT/OPCODE 


8 

4 

4 

1  57 

1  N  1 

RB  1 

8 

4 

4 

16 

1  66 

1  N 

1  RX  1  1 

ADDR  1 

8 

4 

4 

16 

1  58 

1  N 

1  RX  M 

ADDR  1 

IJI  ISCRIPTION:  Bit  number  N  (0  <  N  <  15)  of  the  Derived  Operand.  IX).  is  tested.  Then  the  Condition  Status. 

CS,  is  set  to  indicate  non-zero  if  bit  number  N  of  the  IX)  contains  a  one.  Otherwise  CS  is  set  to 
indicate  zero.  Ibc  MSB  of  the  DO  is  designated  bit  number  zero  and  the  I  .SB  of  the  DO  is 
designated  bit  number  fifteen. 

REGISTER  TRANSFER  DESCRIPTION: 


(CS)  <--  0010 
(CS)  <--  0001 
(CS)  <--  0100 


if  DOn  =  0  and  0  i  N  i  16; 

if  DOk  =  1  and  N  =>  0: 

if  OOh  =  1  and  1  1  N  i  15; 


REGISTERS  AFFECTED:  CS 


TBIi.lB.IBI 


16 


268 


MIL-SfD'1750A  (USAF) 
2  July  1980 


5.6  I  CM  .iikI  si.  !  hu. 

ADDR  MOnf  mnemonic 

D  TSB  N.AODft 

DX  TSB  N.AODR.RX 


lOIIMAl /OPCODE 

8  4  4  16 


I  59  I  N  I  RX  I  i  AOOR 


DUSCKIPTTON:  Bit  number  N  (0  <  N  <  15)  of  the  Derived  Operand,  (X),  is  tested  and  set  to  one.  'Ilic  CS  is  set 
according  to  the  test. 


Note:  External  memory  accesses  shall  be  inhibited  until  this  inslaiction  is  complete. 

REGISTER  TRANSFER 


(CS)  <--  0010 
(CS)  <--  0001 
(CS)  <--  0100 


and 

if 

if 


(OOn)  <--  1  if  0O„  =  0  and  0  1  N  <  15; 
(DO„)  =  1  and  N  =  0; 

(00„)  =  1  and  1  <  N  1  15: 


REGISTERS  AFFECTED:  CS 


I 
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ADDS  MODE  MNEMONIC 


R  SVBR  RA.RB 


FORMAT /OPCODE 
8  4  4 

I  5A  I  RA  I  RB  I 


1  TP<irR  IPTION :  nit  number  N  (0  <  N  <  15)  of  the  register  RB  is  set  to  one  where  the  least  signmeant  fmo  bits  of  ^ 

the  toniems  of  register  R  A  is  N.  Bits  (RA)o-,  i '^vc  no  effect  on  the  operation.  IfKA  -  RB.  Utc 
the  count  is  determined  first  and  then  die  appropriate  bit  is  changed. 


register  transfer  DESCRIPTION: 


(RB)n  <--  1  where  N  =  (RA)i2-i6: 
RFGISTERS  AFFECTEfl:  RB 


SVBR 


J8 
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5.8  Ros.?i  viifMbk-  hic  in  register. 

ADDR  MOJJt  MNEMONIC  FORMAT/OPCODE 

8  4  4 

R  RVBR  RA.RB  |  6C  |  RA  |  RB  | 

DI'SCRII^'I'ION:  Hit  number  N  (0  <  N  <  15)  of  register  RR  is  set  to  zero  where  the  least  significant  four  bits  of  the 
contents  of  regiatcr  RA  is  N.  Bits(RA)o.||  have  no  effect  on  the  operation.  If  RA  =  RIJ,  then  the 
count  is  determined  first  and  then  the  appropriate  bit  is  changed. 

REGISTER  TRANSFER  DESCRIPTION: 

(RB)n  <--  0  whare  N  =  (RA)j2.,j: 

REGISTERS  AFFECTED:  RB 
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5.9  l  est  variable  bit  in  register. 

AUDII  MODE  MNEMONIC  f Of(MA I /OPCODE 

8  4  4 

R  TVBR  RA.RB  |  5E  (  RA  |  RB  ( 

IJhSCKIP  riON:  Bit  number  N  (0  <  N  <  15)of  rcitistcr  kB  is  icslcti  wlioic  the  Ic.isl  si^iulitani  fuin  bits  of  the 
contents  of  register  RA  is  N.  Ihc  Condition  Stutus.  CS,  is  tlieii  set  (n  indiciitc  ndir/em  if  hit 
ninnbcr  N  of  register  RB  is  a  one.  Otherwise.  CS  is  set  to  indicate  /ero. 

HEGISIER  TRANSFER  DESCRIPTION: 

N  =  (R^)i2-15 


(CS) 

<-'  0010 

if 

(RB„) 

=  0 

and 

0 

< 

N 

< 

15: 

(CS) 

0001 

,  f 

(RBn) 

=  1 

and 

N 

0 

(CS) 

<-'  0100 

if 

(RBn) 

=  1 

and 

1 

< 

N 

< 

15; 

REGISTERS  AFFECTED:  CS 


IV  UR 
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5  y'jLi.!''!i!i'iiica]. 

AUJIR  MODE  MNEMONIC 


R  SLL  RB,N 


I  ORMA I /OPCODE 
8  4  4 


I  60  |N-1  I  RB  I  1  <  N  <  16 


1)1  SC.KII‘1  KIN:  Ihe  contents  ot'dic  Derived  Address,  DA  (i.e.,  the  contents  of  register  RB)  arc  shifted  left 
logically  N  positions,  llie  shifted  result  is  stored  in  RB.  I  he  logical  shift  left  operation  is  as 
follows:  zeros  enter  the  least  significant  bit  position  (bit  15)  and  bits  shifted  out  of  the  sign  bit 
position  (bit  0)  arc  lost.  The  condition  status.  CS.  is  set  based  on  the  result  in  register  RB. 


Note:  N-1  =  0  represenLs  a  shift  of  one  position. 


N-1  =  15  represents  a  shift  of  sixteen  positions. 

0 

15 

EXAMPLE ;  RB  Before  Shift 

1  sabc| 

defg  1 

hijk| 

Imnp  1 

RB  After  Shift  (N=4) 

1  dofgl 

hijk| 

Imnp  1 

00001 

REGISTER  TRANSFER  DESCRIPTION: 


(R3) 

<--  (RB) 

Shifted  left 

(CS) 

<--  0010 

if 

(RB)  «  0 

;cs) 

<--  0001 

if 

(RB)  <  0 

■CS) 

<--  0100 

if 

(RB)  >  0 

REGISTERS  AFFECTED; 

RB.  CS 

N  positions; 


41  SLL 
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5.11  Shift  right  lorii.:nl. 

ADDR  MODE  MNFMONIC 


R  SRL  RB.N 


FORMAT /OPCODE 
8  4  4 


I  61  |N-1  I  RB  I  1  <  N  <  16 


1)1  SC'RID'I'ION:  'llic  contents  of  the  IX'riscd  A  ulrcss.  DA  (i.c.,  the  eontctiis  of  re.  isici  KIT),  are  ^hiiied  right 
logically  N  posiiioiis.  1  ho  shitted  o  suit  is  stored  in  Kll.  I  he  logical  shift  rieht  o|>ei  .niuii  is  as 
follows:  zeros  enter  the  sign  hit  position  (hit  (1)  and  hits  shifted  out  of  the  least  ‘.naifis  mi  hit 
position  (bit  15)  are  lost.  1  nc  condition  status.  (  S,  is  set  based  on  the  result  in  legislci  Ull. 

Note;  N-1  =  0  represents  .i  shift  of  one  position. 

N-1  =  15  leproscnts  a  shift  of  sixteen  positions. 

0  15 


EXAMPLE:  RB  Before  Shift  |  sabc|  defg|  hijk|  linnp| 


RB  After  Shift  (N^A)  . . 

1  0000|  sabej  defgl  hijk] 


REGISTER  TRANSFER  DESCRIPTION: 


(RB)  <--  (RB)  Shifted  right  logically  by  N  positions; 


(CS)  <-- 
(CS)  <- 
(CS)  <-- 


OCIO  if 
0001  if 
0100  if 


(RB)  =  0 
(RB)  <  0 
(RB)  >  0 

RB,  CS 


REGISTERS  AFFECTED: 


SRI. 
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5.12  Shift  right  .irithmctic. 

ADDR  MODE  MNEMONIC  r ORMAT/OPCQDE 

8  4  4 

R  SRA  RB,N  1  62  |N-1  |  RB  |  1  i  N  1  16 

l)l-'SCRIP'l  ION:  The  conlcnLs  of  the  Derived  Address.  DA  (ic.,  the  ii--  .■nis  of  register  Rll).  arc  shifted  right 

ai  ithmcliciilly  N  positions,  llic  shifted  result  is  stun  i  KU.  Ilic  iiriilimctic  right  shift  operation 
is  as  folltiws;  the  sign  bit,  'vhich  is  not  changed,  is  copied  into  tlic  next  position  for  each  position 
shifted  and  bits  shifted  out  of  the  least  significant  bit  position  (bit  15)  arc  lose  ’1116  condition 
status,  CS.  is  set  based  on  the  result  in  register  RB. 

Note:  N- 1  =  0  represents  a  shift  of  one  position. 

N-1  =  15  represents  a  shift  of  sixteen  positions. 


0 

15 

EXAMPLE:  RB  Before  Shift 

1  sabc|  defgl 

hijk| 

Imnp  1 

RB  After  Shift  (N»4) 

1  ssss|  sabcl 

defgl 

hijk) 

register  transfer 


(RB)  <--  (RB)  Shifted  right  arithmetically  by  N  positions; 


(CS)  <--  0010 

if 

(RB)  =  0: 

(CS)  <-  0001 

if 

(RB)  <  0: 

(CS)  <--  0100 

if 

(RB)  >  0: 

REGISTERS  AFFE 

vIEO 

RB.  CS 

Mil -SrD-1750A  (USAF) 

2  July  1980 

5.13  Shift  left  cyclic. 

ADDR  MODE  MWEMOWIC  FORMAT /OPCODE 

8  4  4 


R  SLC  RB.N  I  63  jN-l  |  RB  1  1  <  N  <  16 


DHSCRIPnON  :  The  contents  of  the  Derived  Address,  DA  (i.c.,  the  contents  of  register  RB),  arc  shifted  left 
cyclically  N  positions.  The  shifted  result  is  stored  in  RB.  Ihe  cyclic  left  shift  operation  is  as 
follows;  bits  shifted  out  of  the  sign  bit  position  (hit  0)  enter  tlic  least  significant  bit  position  (bit 
15)  and,  consequently,  no  bits  are  lost.  Ihc  conditions  status,  CS,  is  set  based  on  the  result  in  RB. 

Note:  N-1  =  0  represents  a  shift  of  one  position. 


N  -l  =  15  represents  a  shift  of  sixteen  positions. 

0 

15 

EXAMPLE;  RB  Before  Shift 

1  sabej 

defg  1 

hijkl 

Imnp  1 

RB  After  Shift  (N=4) 

1  defgi 

hijkl 

Imnp  1 

sabc  1 

REGISTER  TRANSFER  DESCRIPTION: 

(RB)  <--  (RB)  Shifted  left  cyclically  by  N  positions: 


(CS)  0010  if 

(RB) 

=  0 

(CS)  s'--  0001  If 

(RB) 

<  0 

(CS)  <--  OlOO  if 

(RB) 

>  0 

RCGISTLRS  AFFLCfED; 

RB 

,  CS 

SIC 
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I 


< 


5.14  lldubic  sliil’t  k  it  logical. 
ADDR  MODE  MNEMONIC 


R  DSLL  RB.N 


FORMAT /OPCODE 

8  4  4 


I  65  |N-1  I  RB  I  1  i  N  <  16 


OIISCRIPI'ION:  'Ilic  concatenated  contents  of  the  Derived  Address.  DA,  and  DA  + 1  (i.e.,  the  concatenated 

contents  of  Rlland  Rfl+  1),  arc  shifted  left  logically  N  positions.  The  shifted  results  arc  stored  in 
RB  and  RB-e  1.  The  double  left  shift  logical  operation  is  as  follows:  zeros  enter  the  least 
significant  bit  position  of  RB+  1.  bits  shifted  out  of  the  sign  bit  position  of  RB  + 1  enter  the  least 
significant  bit  of  RB  and  bits  shifted  out  of  the  sign  bit  position  of  RB  arc  lose  ITic  condition 
status,  CS.  is  set  based  on  the  result  in  registers  RB  and  RB+ 1. 

Note:  N- 1  =  0  represents  a  shift  of  one  position. 

N- 1  =  15  represents  a  shift  of  sixteen  positions. 


EXAMPLE 

RB, 

RB+l  Before 

Shift 

0 

RB 

15 

0  RB+l 

16 

Is^abcj 

defgl 

hijk|  Imnpl 

|S2qrs|  tuvw|  xyzz| 

zzzz  1 

RB, 

RB+l  After 

Shift  (M=4) 

0 

RB 

16 

0  RB+l 

16 

1  defgl 

hijkl 

1mnp|$2qrs| 

1  tuvw|  xyzz|  zzzz| 

00001 

REGISTER 

transfer 

DESCRIPTION: 

(RB, 

RB+i; 

I  <-- 

(RB, 

,RB+1)  Shifted  left  logically  by  N  positions; 

(CS) 

<-- 

0010 

if 

(RB,RB+1)  »  0; 

(CS) 

0001 

if 

(RB.RB+1)  <  0; 

(CS) 

<-- 

0100 

if 

(RB,PB+1)  >  0; 

AFFECTED:  RB.  RB+l,  CS 
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5.15  Double  shift  riehi.  loeic;il. 
ADDR  MOPE  MNEMONIC 


R  DSRL  RB.N 


FORMAT/OPCODE 

8  4  4 


1  66  |N-1  I  RB  I  1  <  N  <  16 


Dl-SCRlP^nON:  'llic  concatenated  contents  of  the  I'lerivcd  Address,  DA,  and  DA  + 1  (i.e.,  the  concatenated 

contents  of  Rli  and  RR+  1),  are  shifted  right  logically  N  positions.  Hie  shifted  results  arc  stored 
in  RH  and  Rl!  F 1.  'ITie  double  logical  right  shift  operation  is  as  follows:  zeros  enter  the  sign  bit 
position  of  RIl,  bits  .shifted  out  of  the  least  .significant  bit  position  of  Rl)  enter  the  .sign  bit  position 
of  RB  + 1  and  bits  shifted  out  of  the  least  significant  bit  position  of  RU+  1  arc  lost.  I'hc  condition 
status,  CS,  is  set  based  on  the  result  in  register  RU  and  RB  + 1. 

Note:  N- 1  =  0  represents  a  shift  of  one  position, 

N-1  =  15  represents  a  shift  of  sixteen  positions. 


EXAMPLE 

RB, 

RB+1 

Before 

Shift 

0 

RB 

15 

0 

RB+1 

15 

1 $iabc| 

defgl 

hijkl 

Imnp) 

|S2qrsl 

tuvw| 

xyzzi 

ZZZZ  1 

RB, 

RB+1 

After 

Shift  (N= 

0 

RB 

IS 

0 

RB+1 

15 

1  OOOOj 

s^abej 

defgl 

hijkl 

1  Imnpl 

S2qrs| 

tuvw| 

xyzz| 

REGISTER  TRANSFER  DESCRIPTION: 

(RB,RB+1)  <--  (RB,RB+1)  Shifted  right  logically  by  N  positions: 


(CS) 

<- 

0010 

if 

(BB,RB+1)  = 

(CS) 

<-■ 

0001 

if 

(RB.RB+1)  < 

(CS) 

<-• 

0100 

if 

(RB,RB+1)  > 

REGISTERS  AFFECTED:  RB,  RB+1 ,  CS 


;|  DSRL  46 

‘1 
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5.16  Doiihlc  sliill  rp'ht  ,ii kIiiiicuc. 

ADOR  HODF  MNfMONIC  FORMA I/OPCODE 

8  4  4 

R  DSRA  RB.N  |  67  |N'l  |  RB  |  1  <  N  1  16 


IJIISCKII’I'ION:  The  concatcnntcd  contents  of  the  Derived  Address.  DA.  and  DA  +  1  (i.e..  the  concatenated 

contents  of  RU  and  RH  + 1).  arc  sliiftcd  right  aritlimciically  N  positions.  Ihc  shifted  results  are 
stored  in  RB  and  RB+  1.  'Die  double  right  stiift  arithmetic  operation  is  as  follows:  tlie  sign  bit  of 
RB.  which  is  not  changed,  is  copied  into  the  next  position  for  each  position  shifted,  bits  shifted 
out  of  the  least  significant  position  of  RB  enter  the  sign  bit  position  of  RB  + 1,  and  bits  shifted  out 
of  the  least  significant  bit  position  of  RB+ 1  are  lost  'Die  condition  status,  CS,  is  set  based  on  the 
result  in  register  RB  and  RB+ 1. 

Note:  NT  =  0  represents  a  shift  of  one  position. 

NT  =  15  represents  a  shift  of  sixteen  positions. 

EXAMPLE;  RB ,  RBs-1  Before  Shift 
0  RB  16  0  RB+l  16 


|sjabc|  defgl  hijk|  1mnp|  |s2qrs|  tuvw|  xyzz|  zzzz| 


RB.  RB+1  After  Shift  (N>=4) 

0  RB  16  0  RB-Fl  16 

Isisis^s^l  s^abcl  defgl  hijkj  |1innp|  S2qrs|  tuvw|  xyzz| 

REGISTER  TRANSFER  DESCRIPTION: 

(RB.RB+1)  <--  (RB.RB+l)  Shifted  right  arithmetically  by  N  positions; 

(CS)  <--  0010  if  (RB.RB+1)  =  0; 

(CS)  <--  0001  if  (RB,RB+1)  <  0; 

(CS)  <--  0100  if  (RB.RB+1)  >  0; 

registers  AFFLCTEP:  RB.  RB+1.  CS 
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2  July  1980 

5  17  IXuiblc  shift  left  cyclic. 

ADDR  MODE  MNEMONIC  FORMAI/OPCODE 

8  4  4 

R  DSLC  RB.N  |  68  |N-1  |  RB  |  1  <  N  <  16 


(■ 

I 


I  ll'SCRIKI  ION'  I'hcconcatcniitcd  contents  of  the  Derived  Address,  DA, and  DA-f  1  (i.c.,  the  conc.itenated 

contents  of  Kit  aiul  RB+  1),  are  shifted  left  tyilteallv  N  positions.  Ihe  si  lifted  results  .ire  sloied  in 
KH  and  RH  t  1.  Ihe  double  left  shift  <  yelie  oiK'ralion  is  as  follows:  hits  sliiticd  out  of  the  si  'ii  bit 
position  of  Rlt  enter  the  least  sitnificaiit  hit  position  of  1<H+  I,  bits  shifted  out  of  the  sign  Int 
position  of  KH  I  I  enter  the  least  significant  bit  position  of  RB,  and.  consequently .  no  hits  are  lost 
Ihe  condition  status.  ('S,  is  set  b.iscd  on  the  result  in  KB  and  RB  +  1. 

Note:  N  1  -  0  repiescntsa  shift  ofone  pcisititin. 

N-1  -  15  represents  a  shift  of  sixteen  positions. 


EXAMPLE 

RB, 

RB>1 

Before 

Shift 

0 

RB 

15 

0  RB+1  15 

Is^abcl 

de<'g  1 

hijkl 

linnp  1 

Is^qrsj  tuvw|  xyzzj  zzzz| 

RB. 

RB+1 

After 

Shift  (N=4) 

0 

RB 

16 

0  RB+1  15 

Idefgl 

hijkl 

Imnpl 

S2qrs| 

Ituvwl  xyzz|  zzzz|  S|abc| 

REGISTER  TRANSFER  DESCRIPTION: 


(RB, 

RB+1) 

<-  - 

(RB. 

RB+l)  Shifted  left  cyclically  by  N  positions 

(CS) 

<-- 

0010 

if 

(RB,RB+1)  =  0; 

(CS) 

<-- 

0001 

if 

(RB,RB+1)  <  0: 

(CS) 

<-- 

0100 

if 

(RB,RB+1)  >  0; 

REGISTERS  AFFECTED:  RB ,  RB+1,  fS 
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MIL-STO-1750A  (USAF) 
2  July  1960 

5.1H  Shill  limical.  giiiiit  III  icnisicr. 

AOOR  MODE  MWEMONIC  FOHMAT/QPCQPE 

8  4  4 

R  SLR  RA.RB  |  6A  |  RA  |  RB  |  | ( RB ) |  1  16 


DKSC'KID  IION:  ITic  conicivLs  of  register  RA  arc  shifted  logically  N  positions,  where  N  is  the  contents  of  register 
KH.  If  N  is  positive  ((RBo)-O).  then  tire  shift  direction  is  left;  if  N  is  negative  (2's  complement 
nutation.  (Rlig)=  1).  then  the  shift  direction  is  right.  Ilic  condition  status,  CS,  is  set  based  on  the 
result  in  RA. 

Note:  N  =  0  represents  a  shift  of  zero  positions. 

If  |N|  >  16,  the  fixed  point  overflow  occurs,  no  shifting  takes  place,  and  this  instruction  is  treated 
as  a  NOP  (see  page  137). 

The  contents  of  RB  remain  unchanged,  unless  RA  =  RB;  in  this  event  the  contents  arc  shifted  N 
positions. 

(Sec  "1  Icscription"  of  the  logical  shift  instructions,  SLL  and  SRI,  (see  pages  41  and  42),  for  the 
definition  of  shift  operations.) 

REGISTER  TRANSFER  DESCRIPTION; 

Pli  <--  1,  exit,  if  |N|  >  16; 

(RA)  <--  (RA)  Shifted  left  logically  by  (RB)  positions, 
if  0  <  (RB)  i  16; 

(RA)  <--  (RA)  Shifted  right  logically  by  -(RB)  positions, 
if  0  >  (RB)  >  -16; 


(CS) 

0010 

if 

(RA) 

=  0; 

(CS) 

0001 

if 

(RA) 

<  0; 

(CS)  <-- 

0100 

if 

(RA) 

>  0; 

REGISTERS  AFFECTED:  RA .  RB .  CS,  PI 


49  SLR 

281 


MIL-STO- 1750A  (USAF) 
2  July  1980 


5.19  Shift  aiJiliiuciic.  count  in  rogistcr. 
ADDR  MO nr  MNEMONIC 


SAR  RA.RB 


tORMA I /OPCODE 
8  4  4 


I  6B  1  RA  I  RB  I  |(RB)|  <  16 


DI  ^SCRIF'I'ION:  'Hu.'  contents  of  register  RA  arc  shifted  arithmetically  N  positions,  where  N  is  the  contents  of 
register  RIJ.  If  N  is  positive  ((RI5Q)  =  0),thcn  the  shift  direction  is  left:  if  Nl  is  ncgaioe  (?.'s 
complement  notation.  (RIS,))  -  1 ),  then  die  shift  direction  is  right.  Ilie  condition  status.  is  set 
based  oil  the  result  in  RA. 

N  =  0  represents  a  shift  of  zero  positions. 

If  |N|  >  16,  die  fixed  point  overflow  occtirs,  no  shifting  takes  place,  and  this  instruction  is  treated 
as  a  NOR  (see  page  137). 

The  contents  of  RB  remain  unchanged,  unless  RA  =  RB;  in  diis  event,  the  eonteiiLs  arc  shifted  N 
positions. 

(See  "Description"  of  the  arithmetic  shift  instruction  SRA  (see  page  43)  for  definition  of  the  right 
shift  operation.  Left  shift  causes  "/.cros”  to  be  shifted  into  low  order  position  of  result.) 

Fixed  point  overfiow  occurs  if  the  sign  bit  changes  during  a  left  shift. 

TRANSFER  DESCRIPTION: 

PI4  <--  1.  exit,  if  |N1  >  16; 

(RA)  <--  (RA)  Shifted  left  arithmetically  (RB)  positions, 
if  16  >  (RB)  >  0; 

(RA)  <--  (RA)  Shifted  right  arithmetically  -(RB)  positions, 
if  0  >  (RB)  >  -16; 

PI4  <--  1.  if  (RAg)  changes  during  the  shift: 


(CS) 

<-- 

0010 

if 

(RA) 

=  0: 

(CS) 

<-- 

0001 

if 

(RA) 

<  0; 

(CS) 

<-- 

0100 

if 

(RA) 

>  0; 

REGISIERS  AFEECTED:  RA .  RB ,  CS,  PI 


Note: 


REGISTER 


SAR 
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5.20  Shift  cyclic,  coiiiu  in  rcnistcr. 

ADDR  MOnr.  MNEMONIC  FORMAT/OPCOnf 

8  4  4 

R  SCR  RA.RB  |  6C  |  RA  |  RB  |  |(RB)|  i  16 


IJKSCRIKI  ION:  llic  cunfcnts  of  register  RA  are  shifted  cyclically  N  positions,  where  N  is  the  contents  of  register 
Rll.  If  N  is  positive  ((Rllo)=0).  then  die  shift  direction  is  left:  if  N  is  negative  (2’s  complement 
notation,  (R  Ro)=  1).  then  tlie  shift  direction  is  right  The  condition  status,  CS,  is  set  based  on  the 
result  in  RA, 


Note:  N  =  0  represents  a  shift  of  zero  positions. 

If  |N|  >  16,  the  fixed  point  overflow  occurs,  no  shifting  takes  place,  and  this  instruction  is  treated 
as  a  NOP  (see  page  137). 

(See  "Description"  of  the  cyclic  shift  instruction,  SLC  (see  page  44),  for  definition  of  shift 
operations.) 

llte  contents  of  RB  remain  unchanged,  unless  RA  =  RB  in  this  event,  the  contents  are  shifted  N 
positions. 

REGISTER  TRANSFER  DESCRIPTION; 


PI4  <--  1,  exit,  if  |N|  >  16; 

(RA)  <--  (RA)  Shifted  left  cyclically  by  (RB)  positions, 
if  0  <  (RB)  i  16; 

(RA)  <--  (RA)  Shifted  right  cyclically- by  - (RB)  positions, 
if  0  >  (RB)  2  -16; 


(CS)  <--  0010  if 

(RA) 

=  0; 

(CS)  <--  0001  if 

(RA) 

<  0; 

(CS)  S--  0100  if 

(RA) 

>  0; 

REGISTERS  AFFECTED 

RA 

RB.  CS.  PI 

51 
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5.21  IJoiiblc  shift  loekal.  count  in  icgister. 

ADDR  MOD€  MNEMONIC  F QRMAT /OPCODE 

8  4  4 


R  OSLR  RA.RB  |  6D  |  RA  |  RB  |  |(RB)|  1  32 


DI-SCRIPTION:  The  concatenated  contents  of  registers  RA  and  RA  +  1  are  shifted  logically  N  positions  where 
register  RB  contains  the  count.  N.  If  the  count  is  positive  ((RBo)-®)-  direction  is 

left.  If  the  count  is  negative  (2's  complement  notation,  (RHq)=  1 ).  then  the  shift  dircxiioi’  is  riglu. 
'Ihc  condition  status.  CS.  is  set  based  on  the  result  in  RA  and  RA  + 1. 

Note:  N  =  0  represents  a  shift  of  zero  positions. 

If  (N|  >  32,  the  fixed  point  overflow  occurs,  no  shifting  occurs,  and  this  instruction  is  treated  .is  a 
NOP  (see  page  1 37). 

(See  "Description"  ofthe  double  shift  logical  instructions.  DSRl  and  DSl.l  .  (see  pages  46  and 
45),  for  definition  of  shift  operations.) 

The  contents  of  RB  remain  unchanged,  unless  RA  =  RB;  in  this  event,  the  contents  are  shifted  N 
positions. 

REGISTER  IRANSFER  DESCRIPTION: 


PI«  <- 

1 ,  exi 

t.  if  |N| 

>  32 

(RA,RA+1 

)  <-- 

(RA,RA+1) 

Shifted  left 

logically  by 

(RB)  positions 

if  32 

>  (RB)  > 

0; 

(RA.RA+l 

,  <-- 

(RA.RA+l) 

Shif 

ted  right 

logically  by 

-(RB)  positions 

if  0 

>  (RB)  > 

-32; 

(CS)  <-- 

0010 

if  (RA, 

RA+1) 

=  0; 

(CS)  <- 

0001 

if  (RA. 

RA+1) 

<  0: 

(CS)  <-- 

0100 

if  (RA, 

RA+1) 

>  0; 

f 


MIL-STD-1750A  (USAF) 
2  July  1980 

5.??.  0<  ''Jii !  iiiciit .  cm  (HI  in  n'l'istor. 


ADDR  MODE 

MNEMONIC 

tORMAT /OPCODE 

8 

4  4 

R 

OSAR  RA.RB 

1  BE 

1  RA  1  RB  1  |(RB)|  i  32 

DFSCUin  ION:  'ITie  concatenated  contents  of  register  UA  and  RA  t  1  arc  shifted  arithmetically  N  positions  where 
register  Rll  contains  die  count.  N.  If  the  count  is  positive  {(RBq)  -  0),  tlicn  the  shift  direction  is 
left.  If  the  count  is  negative  (2’s  complement  notation.  (RHo)=  1).  then  die  shift  direction  is  right 
'Mie  condition  stilus.  CS.  is  set  based  on  the  result  in  RA  and  RA  + 1. 

Note:  N  =  0  represents  a  shift  of  zero  positions. 

If  |N|  >  32,  the  fixed  point  overflow  occurs,  no  shifting  occurs,  and  this  instruction  is  treated  as  a 
NOP  (sec  page  137). 

The  contents  of  R  H  remain  unchanged,  unless  RA  ==  RR;  in  this  event,  the  contents  ate  shifted  N 
positions. 

(See  "Description"  of  the  double  shift  arithmetic  instruction.  DSRA  (sec  page  47).  for  the 
definition  of  the  right  shift  operation.  Ixift  shift  causes  "zeros”  to  be  shift^  into  low  order 
position  of  result) 

Fixed  point  overflow  occurs  if  the  sign  bit  is  changed  during  a  left  shift. 

ftteiSTER  transfer  OESCRIPTtQN: 

PI4  <--  1.  exit,  if  rxt  >  32; 

(RA,RA+1)  <--  (RA,RA+1)  Shifted  left  arithmetically  (RB)  positions, 
if  32  2  (RB)  >  0; 

(RA,RA+1)  <--  (RA,RA+1)  Shifted  right  arithmetically  -(RB)  positions, 
if  0  >  (RB)  >  -32; 

PI4  <--  1,  if  (RAq)  changes  during  the  shift; 


(CS)  <-- 

0010 

if 

(RA,RA+1) 

=  0; 

(CS)  <-- 

0001 

if 

(RA.RA+l) 

<  0; 

(CS)  <-- 

0100 

if 

ERA, RA+1) 

>  0; 

REGISTERS  AFFECTED:  RA,  RA+1 .  RB.  CS.  PI 
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5.23  IJoubIc  shift  cyclic,  coiiiu  in  icpister. 
ADDR  MODE  MNEMONIC 


R  DSCR  RA.RB 


FORMAT /OPCODE 
8  4  4 


I  6F  I  RA  I  RB  I  |(RB)|  <  32 


OHSCRlFriQN :  'Fhc  concatenated  contents  of  registers  RA  and  RA  +  1  are  sliifted  cyclically  N  positions,  where 
register  RB  contains  the  count.  N.  If  the  count  is  positive  {(RB,))-0).  the  shift  direction  is  left.  If 
the  count  is  negative  (2’s complement  notation,  (RBq)=  1),  the  shift  direction  is  right.  TTie 
condition  status,  CS,  is  set  based  on  tlie  result  in  RA  and  RA+  1. 

Note:  N  =  0  represents  a  shift  of  zero  positions. 

If  |N1  >  .12,  the  fixed  point  overflow  occurs,  no  shifting  occurs,  and  this  instruction  is  treated  as  a 
NOP  (sec  page  137). 

(See  "Description"  of  the  double  shift  cyclic  instruction,  DSLC  (see  page  48).  for  the  definition  of 
shift  operations.) 

The  contents  ofRB  remain  unchanged,  unless  RA  =  RB;  in  this  event,  the  contents  arc  shifted  N 
positions. 

REGISTER  TRANSFIER  DESCRIPTION; 

PI4  <--  1.  exit,  if  |N|  >  32; 

(RA.RA+l)  <--  (RA,RA+1)  Shifted  left  cyclically  by  (RB)  positions 
if  32  2  (RB)  >  0; 

(RA,RA+1)  <--  (RA,RA+1)  Shifted  right  cyclically  by  -(RB)  positions 

if  0  >  (RB)  2  -32: 

(CS)  <--  0010  if  (RA,RA+1)  «  0; 

(CS)  <--  0001  if  (WA.RA+1)  <  0; 

(CS)  <--  0100  if  (RA.RA+l)  >  0; 

REGISTERS  AFFECTED:  RA,  RA+l,  RB ,  CS.  PI 


\ 


DSCR 
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MIL-SrD-1750A  (USAF) 
2  July  1980 


5.24  Juinn  on  condiiion. 
ADDR  MODE  MNEMONIC 


0  JC  C, LABEL 

DX  JC  C. LABEL. RX 


I  JCI  C.ADOR 

IX  JCI  C.ADOR, RX 


FORMAT /OPCODE 


8 

4 

4 

16 

1  70 

1  c  1 

1  RX  1  1 

LABEL  1 

8 

4 

4 

16 

1  71 

1  c  1 

1  RX  1  1 

ADDR  1 

DRSCKIKI  ION:  ITiis  is  a  conditional  jump  instruction  wherein  tlie  instruction  sequence  jumps  to  the  IDcrivcd 
Address,  DA,  if  a  logical  one  results  from  the  following  operation: 

(1)  The  4-bit  C  field  is  bit-by-bit  ANDed  with  the  4-bit  condition  status,  CS 

(2)  The  resulting  4-bits  arc  ORcd  together 

(3)  orifC  =  7orC  =  F: 

Otherwise,  the  next  sequential  instruction  is  executed. 


Cond 

it ion  Code 

£i6  J-tupg 

M08in9ni.c 

0000 

0 

NOP 

- 

- 

- 

0001 

1 

lass  than  (zero) 

LT 

LZ 

M 

0010 

2 

equal  to  (zero) 

EQ 

EZ 

- 

0011 

3 

less  than  or  equal  to 

(zero) 

LE 

LEZ 

NP 

0100 

4 

greater  than  (zero) 

GT 

GZ 

P 

0101 

5 

not  equal  to  (zero) 

NE 

NZ 

- 

0110 

6 

greater  than  or  equal 

to  (zero) 

GE 

GEZ 

NM 

0111 

7 

unconditional 

- 

- 

- 

1000 

8 

carry 

CY 

- 

- 

1001 

9 

carry  or  LT 

- 

- 

- 

1010 

A 

carry  or  EQ 

- 

- 

- 

1011 

B 

carry  or  LE 

- 

- 

- 

1100 

C 

carry  or  GT 

- 

- 

1101 

D 

carry  or  NE 

- 

- 

- 

1110 

E 

carry  or  6E 

- 

- 

- 

nil 

F 

unconditional 

- 

- 

- 
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RFGISTER  TRANSFER  DESCRIPTION: 

(1C)  <--  DA  if  C  =  7.  or 
if  C  -  F.  or 

if  (Cot  CSo)  V  (C,t  CS,)  V  (C^f  CS2)  V  (Cgt  CS3) 
REGISTERS  AFFECTED:  IC  (if  jump  is  executed) 


\ 


% 
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2  July  1980 


5  }'>  Jump  U)  sulir.mUiie. 

ADDR  MQBL  MNI MONIC 


D 

DX 


JS 

JS 


RA. label 
KA. LABEL, RX 


fORMAI /OPCODE 

8  4  4  16 

I  72  I  RA  I  RX  I  I  LABEL 


DI-'SCKIKI  ION:  llic  value  of  the  instniction  counter  (the  address  of  the  next  sequential  instruction)  is  stored  into 
rejuster  RA,  nien,  the  IC  is  set  to  tlie  derived  address,  DA.  thus  effeeting  tlie  jump.  I  his  sets  up 
the  return  from  subroutine  to  the  address  stored  in  the  register  RA,  i.e..  an  indexed  unconditional 
jump  from  l(x;ation  zero  using  RA  as  the  index  register  shall  transfer  control  to  tlte  instruction 
following  the  JS  instruction. 

Note:  If  KA  ~  RX.  then  tlte  derived  addrestv,  DA,  is  calculated  before  the  1C  is  stored  in  RA. 

REGISTER  TRANSFER  DESCRIPTION: 

(RA)  <--  (IC): 

(IC)  OA; 

REGISTERS  AFFECTED:  RA.  IC 


MIL-STD-1750A  (USAF) 
2  July  1980 


ADDR  MODE  MNEMONIC 


SOJ  RA. LABEL 
SOJ  RA. LABEL, RX 


4  4 


I  73  I  RA  I  RX  I 


LABEL  I 


IJHSCRIPI'ION:  'Ilie  16  hit  contents  of  register  RA  arc  decremented  by  one.  'I'hcn  if  the  content  of  register  RA  is 
zero,  the  next  sequential  instruction  is  executed.  If  the  content  of  register  RA  is  non-zero,  then  a 
jump  to  the  IXrivcd  Address.  DA,  occurs. 

Note:  If  RA  =  RX,  then  the  derived  address,  DA.  is  calculated  before  RA  is  decremented. 

REGISTER  TRANSFER  DESCRIPTION: 

(RA)  <--  (RA)  -  1; 

(IC)  <--  DA  if  (RA)  *  0; 


(CS)  <--  0010  if  (RA)  =  0 
(CS)  <--  0001  if  (RA)  <  0 
(CS)  <--  0100  if  (RA)  >  0 


RA,  CS,  IC  (if  the  jump  is  executed) 


MIL-STD-1750A  (USAF) 
2  July  1980 


3.28  llranch  it  ccmal  ti>(/orol. 

ADDR  MOUE  MNEMONIC  I ORMA I /OPCODE 

8  8 

ICR  BEZ  LABEL  |  75  |  D  |  -128  ^  I)  <  127 

DI-SCRIPI'ION:  A  program  branch  is  made  to  I  ABI  J  .  i  c  .  the  Derived  Address,  DA,  il'llK-  ( oiulilion  stains,  (' 
indicates  that  the  previous  result  which  set  the  (,S  is  equal  to  (zero)  Diliei  w  isc.  the  next 
sequential  instruction  is  executed. 

REGISTER  TRANSFER  DESCRIPIION: 

(IC)  <--  DA  if  (CS)  =  XOIO; 

REGISTERS  AFFECTED :  IC  (if  the  jump  is  executed) 


!• 

F 

t 


OF/ 


Wl 
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S.,")  los-.  III. Ill  I/croI. 

AnOR  Munt  MWLHOmC 

ICR  BIT  LABEL 


lORHAI /ORCOOL 
8  8 


I  76  I  D  I  -128  <  D  <  127 


DI-SCKIPriON:  A  propriim  branch  is  made  to  I.ABI-J.,  i.c..  the  IJcrivcd  Address.  DA.  if  the  condition  status,  CS, 
indicates  that  the  previous  result  which  set  the  CS  is  less  than  (zero).  Otherwise,  the  next 
sequential  instruction  is  executed. 

REGISTFR  TRANSFER  DESCRIPTION: 

(IC)  <--  DA  if  (CS)  =  XOOl; 

REGISTERS  AFFECTED:  IC  (if  the  jump  is  executed) 
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5,30  llrunch  U)  executive. 

ADDR  MODE  MNEMONIC  FOPMAT/OPCODE 

8  4  4 

S  BEX  N  I  77  |0000|  N  | 


DF.SCRIP  I  ION:  This  insiruclion  provides  a  means  to  jump  to  a  routine  in  another  address  state,  AS.  it  is  typically 
used  to  make  controlled,  protected  calls  to  an  executive.  Ihe  4-bit  literal  N  selects  one  of  16 
executive  entry  points  to  be  used.  Hxecuiion  of  this  instruction  causes  an  interrupt  to  occur  using 
the  KXHC  call  interrupt  vccioi  (interrupt  S).  Ihe  new  IC  is  loaded  from  the  Nth  location 
following  the  SW  in  tlte  new  processor  state.  'Ihe  linkage  pointer  (1  ,P),  service  pointer  (SVP),  .’nd 
the  new  priKcssor  state  (new  MK,  new  SW,  and  new  1C)  arc  fciclicd  from  address  state  zero.  Ihe 
current  processor  state  (old  MK,  old  SW,  and  old  IC)  arc  stored  in  the  address  state  specified  by 
the  new  SW  AS  field.  Interrupts  arc  disabled  when  Bl-X  is  executed.  'Ihe  l-.X  K.C  call  interrupt 
cannot  be  masked  or  disabled.  Arguments  associated  with  the  HHX  insii  uction  arc  passed  by 
software  convention.  Ihe  pr<x:cssor  lock  and  key  function  is  ignored  when  iliis  instruction  is 
executed.  An  attempt  to  branch  into  an  execute  protected  area  of  memory  shall  result  in  l-T'o 
being  set  to  1. 

REGISTER  TRANSFER  DESCRIPTION: 


(R0,RQ+l.RQ+2)  <--  (MK,SW,IC): 

(SVP)  <--  [2B,6].  where  AS  =  0; 

Pis  <--  1: 

(MK.SW.IC)  <--  [(SVP).(SVP)-H.(SVP)+2+N)],  where  AS  =  0; 
(LP)  <--  [2Ai6],  where  AS  =■  0; 

[(LP) ,(LP)-H,(LP)+2]  <--  (RQ,RQ+l,RQ+2),  where  AS  = 
REGISTERS  AEEECTED:  MK,  SW,  IC,  PI 


Hl-.X 
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5.31  Uranch  if  less  ih.in  or  cuii.il  to  (/crol. 

AODR  MODE  MNEMONIC  FORMA  I  /OPCODE 

8  8 

ICR  BEE  LABEL  |  78  |  D  |  -128  1  0  <  127 

DFSCRIPI  ION:  A  program  branch  is  made  to  I  AHKI ..  i.c.,  the  Derived  Address,  DA,  if  the  condition  status,  CS, 
indicates  tliat  the  previous  result  which  set  the  CS  is  less  than  or  equal  to  (zero).  Otherwise,  the 
next  sequential  instruction  is  executed. 

REGISTER  TRANSFER  DESCRIPTION: 

(IC)  <--  DA  if  (CS)  «  XOlO  or  (CS)  •  XOOl; 

REGISTERS  AFFECTED:  IC  (if  the  jump  is  executsd) 
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5.-' 7  llnintli  ir  greater  than  (/crol. 

AD OR  Moot  MWLMONIC  f ORMAT/QPCOOF 

8  8 

ICR  BGT  LABEL  |  79  |  D  1  -128  <  D  <  127 

DI'SCRIPTION:  A  program  branch  is  made  to  lAllld.,  i.c.,  the  Derived  Address.  DA,  if  the  condition  status,  CS, 
indicates  that  the  previous  result  which  set  the  CS  is  greater  tlian  (zero).  Otherwise,  the  next 
sequential  iiisii  iiction  is  executed. 

REGlSIf R  TRANSFER  OF  SCRIPT  ION: 

( 1C)  <--  DA  if  (CS)  =  XIOO; 

REGISTERS  AF  FECTEO :  IC  (if  the  jump  is  executed) 


HOT 
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5.J.1  Hniiich  If  mu  giii.il  lo  l/crol. 

ADOR  MODI  MNLMOmC  FORMAT/QPCODE 

8  8 

ICR  BNZ  LABEL  |  7A  |  D  |  -128  1  D  1  127 

DI-SCRIKFION:  A  program  branch  is  made  to  MBF.I ,  i.c.,  the  ITerivctl  Address.  UA,  if  the  condition  status,  CS, 
indicates  that  the  previous  result  which  set  the  CS  is  not  equal  to  (/.cro).  Otherwise,  the  next 
sequential  instruction  is  executed. 

REGISTER  TRANSFER  DESCRIPTION: 

(IC)  <--  DA  if  (CS)  «=  XlOO  or  (CS)  =  XOOl; 

REGISTERS  AFFECTED:  IC  (if  the  jump  is  executed) 
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5.. 14  liranch  If  greater  ih.in  or  CQual  to  (  /.ero>. 


ADOR  MODE 

MNEMONIC 

FORMAT/OPCODE 

8 

8 

ICR 

BGE  LABEL 

1  7B 

1  0 

1  -1?8  <  D  <  127 

ni'.SCRIPI  ION:  A  program  branch  is  made  lo  l.ABP.I.,  i.c.,  the  Derived  Address,  DA.  if  the  condit.on  sUitiis,  CS, 
indicates  that  the  previous  result  which  set  die  CS  is  greater  titan  or  equal  to  (/cm).  Othcrvtisc,  the 
next  sequential  instruction  is  executed. 

REGISTER  TRANSEER  DESCRIPTION: 

(IC)  <--  DA  if  (CS)  =  XlOO  or  (CS)  =  XOlO; 

REGISTERS  AFEECTED:  IC  (if  the  jump  is  executed) 


I 
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5.  !5  I  stntus. 

AUOR  MODE  MNEMONIC  EORMA f /OPCODE 


D  LST  AOOR 

DX  LST  ADOR.RX 


I  LST I  AOOR 

IX  LST I  AOOR.RX 


6 

4 

4 

16 

1  7D 

|0000| 

RX  1  1 

ADOR  1 

8 

4 

4 

16 

1  7C 

|0000| 

RX  1  1 

AODR  1 

DI-.SCRIFI'ION:  The  contents  of  the  Derived  Address,  DA.  and  DA  + 1,  and  DA  +  2  arc  loaded  into  the  Interrupt 
Mask  register,  Status  Word  register  and  Instruction  Counter,  respectively.  This  is  a  privileged 
instruction. 

Note:  This  instruction  is  an  unconditional  jump  and  is  typically  used  to  exit  from  an  interrupt  routine. 

DA,  DA  + 1,  and  DA  +  2,  in  this  typical  case,  contain  the  Intenupt  Mask,  Status  Word,  and 
Instruction  Counter  values  for  the  interrupted  program  and  the  execution  of  I.S1'  causes  the 
program  to  return  to  its  status  prior  to  being  intenupted. 

register  TRflWSE-ER  PESCRIPT.tOH; 

(MX.  SW.  IC)  <--  [DA.  OA+l,  DA+2]; 

Rtfi.l51£RS  miSdUl:  MK.  SW,  IC 
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5.36  Stack  1C  and  iiimn  to  subroutine. 

ADOR  MODE  MWEMOWIC  fORHAl /OPCODE 

8  4  4  16 

D  SJS  RA. LABEL  -  - -  -- 

DX  SJS  RA. LABEL. RX  |  7E  |  RA  |  RX  |  |  LABEL  | 


nt'SCRIFTION:  TTic  contents  of  register  RA  arc  decremented  by  one.  I'hc  address  of  the  insiriiciinn  rollowing  the 
SJS  instruction  is  stored  into  die  mcmoiy  location  pointed  to  by  ILA.  Proprain  control  is  Uicn 
transferred  to  the  instruction  at  the  Derived  Address,  I  )A.  RA  is  the  stack  pointer  .ind  c,in  be 
selected  by  die  programmer  as  any  one  of  die  16  general  registers. 

Note:  If  RA  =  RX,  then  die  derived  address.  1)A,  is  calculated  before  RA  is  decremented. 

REGISTER  TRANSFER  DESCRIPTION: 

(RA)  <--  (RA)  -  1; 

[(RA)]  <-  (IC): 

(IC)  <--  DA; 

REGISTERS  AFFECTED:  IC .  RA 
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5  37  liiistick  IC  .mtl  auirn  fruni  siihioulinc. 

ADOR  MODE  MNEMONIC  FORMAT /OPCODE 

8  4  4 

S  URS  RA  I  7F  I  RA  I  0  I 

111  SCRIKFION:  The  contents  of  the  memory  location  pointed  to  by  register  RA  is  loaded  into  the  instruction 
counter,  1C.  RA  is  then  incremented  by  one.  Any  one  of  the  16  general  registers  may  be 
designated  as  the  stack  pointer.  This  instruction  is  the  subroutine  return  for  SJS.  Stack  and  Jump 
to  Subroutine. 

REGISTER  TRANSFER  DESCRIPTION; 

(IC)  <--  [(RA)]; 

(RA)  <--  (RA)  +  1: 

REGISTERS  AFFECTED:  RA.  IC 
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S.38  Single  precision  load. 


ADDR  MODE  MWEMONIC 


FORMAT/OPCODE 


8  4  4 


R 

LR 

RA.RB 

1 

81 

1  RA  1 

RB  1 

4 

2 

2 

8 

B 

LB 

BR.OSPL 

1  0 

|0 

IBR'I 

DSPL  1 

4 

2 

2  4 

4 

BX 

LBX 

BR.RX 

1  4 

|0 

IBR'I  0 

1  RX  1 

8 

4 

4 

ISP 

LISP 

RA,N 

1 

82 

1  RA  1 

N-1  1 

8 

4 

4 

ISN 

LISN 

RA,N 

1 

83 

1  RA  1 

K-1  1 

12  <  BR  <  16 
BR'  =  BR  12 
RA  °  R2 


12  <  BR  <  15 
BR'  =  BR  -  12 
RA  >  R2 


1  <  N  i  16 


1  i  N  i  16 


D  L  RA.ADDR 

DX  L  RA.ADOR.RX 


IM  LIM  RA.OATA 

IMX  LIM  RA.OATA.RX 


I  LI  RA.ADDR 

IX  LI  RA.ADOR.RX 


8 

4 

4 

16 

1  80 

1  RA 

1  RX  1  1 

ADDR  1 

8 

4 

4 

16 

1  85 

1  RA 

1  RX  1  1 

DATA  1 

8 

4 

4 

16 

1  84 

1  RA  1 

1  RX  1  1 

ADDR  1 

DFSCRIPTION:  The  single  precision  Derived  Operand,  IX),  is  loaded  into  the  register  RA.  The  Condition  Status, 
CS.  is  set  based  cn  the  result  in  register  RA. 


1  R.LISP.I.ISN,I.n,l.»X,l  .1  1,1  IM 
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RLOlSTf R  LRANSliJi  DCSCRIPI  ION: 
(RA)  <--  DO; 


(CS) 

<-- 

0010 

if 

(RA) 

=  0; 

(CS) 

<-- 

0001 

if 

(RA) 

<  0; 

(CS) 

<-- 

0100 

if 

(RA) 

>  0; 

REGISTERS  AFFECTED:  RA.  CS 
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5  . 19  Duuhio  Divcision  load. 


ADDR  MODE 

MNEMONIC 

FORMAT/OPCODE 

8 

4 

4 

R 

DLR 

RA.RB 

1  87 

1  RA 

1  RB  1 

4  2 

2 

8 

12  <  BR  15 

BR'  =  BR  12 

RA  >  RO 

B 

OLB 

BR.DSPL 

1  0  |1 

IBR'I 

DSPL  1 

4  2 

2 

4  4 

12  <  BR  <  15 
BR’  =  HR  -  1, 
RA  =  HO 

BX 

OLBX 

BR.RX 

1  4  |0 

IBR'I 

1  (  RX  ( 

D 

DX 

RA.AOOR 

RA.AODR.RX 

8 

4 

4 

16 

DL 

1  86 

1  RA 

1  RX  1  1 

ADDR  1 

8 

4 

4 

16 

I 

IX 

OLI 

OLI 

RA.AOOR 

RA.AODR.RX 

1  88 

1  RA 

1  RX  1  1 

ADDR  1 

DFSCRIPTION:  The  double  precision  Derived  Operand.  DO,  is  loaded  inio  the  register  RA  and  RA  + 1  such  that 
the  MSH  of  DO  is  in  RA.  llie  Condition  Status.  CS,  is  set  based  on  the  result  in  RA  and  RA  + 1. 

REGISTER  TRANSFER  DESCRIPTION: 

(RA,RA+1)  <--  DO; 

(CS)  <--  0010  if  (RA,RA+1)  =  0  {Double  fixed  point  zero): 

(CS)  <--  0001  if  (RA.RA+1)  <  0; 

(CS)  <--  0100  if  (RA,RA+1)  >  0; 

REGISTERS  AFFECTED:  RA,  RA+1 ,  CS 


DI.R.DI  H.DI  llX.DI..ni.l 
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S -)()  I  i.  hI  iiiiillink  luuislurs. 

AIIQR  MODb  MNLMONIC  FORMA  1 /OPCODb 

8  4  4  16 

D  LM  N.ADDR  -  - 

OX  LM  N.ADDR, RX  |  89  |  N  |  RX  |  |  ADOR  | 

0  <  N  <  15 

1)1  SCRIP HON.  T  lie  toiucnts  of  ihc  IX-rivcd  Address.  DA.  arc  loaded  into  register  RO.  then  tlic  contents  of  the 

DA  t- 1  arc  loaded  into  register  R1 . finally,  tlie  contents  of  DA  +  N  arc  loaded  into  RN. 

Hffcctivcly  tins  instruction  allows  tlic  transfer  of  (N  +  1)  words  from  memory  to  the  register  file. 

REGISTER  TRANSFER  DESCRIPTION: 

(RO)  <--  [DA]  ; 

(Rl)  <--  [DA+IJ: 

{R2)  <--  [DA+2J. 


(RN)  <--  [OA+NJ; 

REGISTERS  AFEECTED:  RO  through  RH 
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tOEMAlZQPCOOt 

8  4  4  16 


I  8A  I  RA  I  RX  I  I  ADDR 


Dl'SCRIPI  ION:  The  extended  precision  Hoaiing point  I lerivcd  Operand.  I )0.  is  loaded  into  registers  R A, 

RA  +  1,  and  RA  +  2  such  that  the  most  significant  16-bits  of  the  word  arc  loaded  into  register  RA. 
Hie  condition  status.  CS,  is  set  based  on  the  results  in  registers  R  A,  R  A  +  1 .  and  R  A  +  2. 

REGISTFR  TRANSFER  DESCRIPTION: 


(RA,  RA+1  ,  RA-X2)  <--  00; 


(CS) 

<-- 

0010 

if 

(RA.  RA-H. 

RA-i-2) 

=  0: 

(CS) 

<-- 

0001 

if 

(RA,  RA-H, 

RA-i-2) 

<  0; 

(CS) 

<-- 

0100 

if 

(RA.  RA-i-1. 

RA-H2) 

>  0; 

REGISTERS 

AFFECTED: 

RA.  RA-t-l 

.  RA-X2, 

CS 

5.41  l-Ateiulcd  nrccision  lloatiiig  point  load. 
ADDR  MODE  MNEMONIC 

D  EFL  RA.AODR 

DX  EFL  RA.AODR. RX 


l-Fl 


1 
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5.42  I  (Mcl  fioin  unixT  l)vtc. 


ADDR  MODE 

MNEMONIC 

FORMAT /OPCODE 

LUB 

LUB 

RA.ADOR 

RA.ADOR.RX 

6 

4 

4 

18 

DX 

1  SB 

1  RA  1 

RX  1  1 

ADDR  1 

8 

4 

4 

16 

I 

IX 

LUBI 
LUB  I 

RA.AODR 

RA.ADDR.RX 

1  80 

1  RA  1 

RX  1  1 

ADDR  1 

DI-SCkIP  I'lON:  The  MSH  (upper  byte)  of  tiie  IJcrivcd  Operand.  IX),  is  loaded  into  the  I.SH  (lower  byte)  of 

register  RA.  Tlic  MSH  (upper  byte)  of  RA  is  unaffected.  The  condition  status,  CS,  is  set  based  on 
the  result  in  RA. 

REGISTER  TRANSFER  DESCRIPTION: 

(RA)3.j5  <--  DOq.;; 

(CS)  <--  0010  if  (RA)  =  0; 

(CS)  <--  0001  if  (RA)  <  0; 

(CS)  <--  0100  if  (RA)  >  0; 


REGISTERS  AFFECTED:  RA,  CS 

I. 
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5.4J  1  oaJ  I'roin  lower  bvtc. 


ADDR  MODE 

MNEMONIC 

FORMAT/OPCODE 

D 

LLB 

RA.AOOR 

8 

4 

4 

16 

DX 

LLB 

RA,ADOR,RX 

1  8C 

1  RA  1 

RX  1  1 

ADOR  ( 

I 

LLBI 

RA,ADDR 

8 

4 

4 

16 

IX 

LLBI 

RA,AD0R,RX 

1  BE 

1  RA  1 

RX  1  1 

ADDR  1 

DKSCRIP’I'ION:  Ihc  1,SH  (lower  byte)  of  the  Derived  Operand,  IX),  is  loaded  into  the  LSH  (lower  byte)  of 

register  IIA.  Ihe  MSH  (upper  byte)  of  RA  is  unaffected.  1116  condition  status,  CS,  is  set  based  on 
the  result  in  RA. 

REGISTER  TRANSFER  DESCRIPTION: 

(RA)3_]5  <--  OOg.js; 

(CS)  <--  0010  if  (RA)  =  0; 

(CS)  <--  0001  if  (RA)  <  0; 

(CS)  <--  0100  if  (RA)  >  0; 


S  44  Poo  inultiolc  roi-istcPi  olT  the  slack. 


Mtt-SfO  l/‘jOA  (USAf) 

2  jiJly  i‘)80 


ADDR  Moot  MNEMONIC  I  PUMA . /OPCOOF 

8  4  4 


S  POPM  RA.RB  I  8F  I  PA  I  RO  I 


DF.SCRIPTION:  For  RA  <  RR.  registers  RA  through  RIt  ure  loaded  scquciui..ll>  friim  a  stack  :ii  memory  using  R 15 
us  the  stack  pointer. 

For  RA  >  RH,  registers  RA  through  R14  and  then  RO  through  RH  arc  loaded  sequentially  from 
the  stack. 

In  both  cases, 

a.  as  each  word  is  popped  from  the  stack,  RIS  is  incremented  by  one: 

b.  if  RIS  is  included  in  the  transfer,  then  it  is  effectively  ignored; 

c.  on  completion,  RIS  points  to  the  top  word  of  the  stack  remaining. 

Rf£.I§TER  transfer  DESCRIPTION: 

if  RA  RB  than  4 

for  i  »  0  thru  RB  -  RA  do 
bog  in 

if  RA  ♦  1  A  15  then  (RA  ♦  1)  <--  [(R15)]; 

(R16)  <—  (R16)  +  1; 
ond; 

el  so 

begin 

for  1*0  thru  16  -  RA  do 
begin 

if  RA  +  1  A  16  then  (RA  +  i)  <--  [(R15)]: 

(R15)  <--  (R16)  +  1; 
endi 

for  i  »  0  thru  RB  do 
begin 

(i)  <-  [(R16)]. 

(R15)  <--  (R16)  +  1; 
end; 

end; 

REGISTERS  AFFECTED:  RA  through  R14,  RO  through  RB.  R16 
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5.45  Sinalc  precision  store. 
ADDR  MOPE  MNEMONIC 


0 

DX 


I 

IX 


ST 

ST 


ST  I 
ST  I 


RA.AOOR 

RA.ADOR.RX 


RA.ADOR 

RA.ADOR.RX 


FQRMAT/OPCQDE 


4 

2 

2 

8 

B 

STB 

BR.DSPL 

1  0 

12 

IBR'I 

DSPL  1 

4 

2 

2  4 

4 

BX 

STBX 

BR.RX 

i  4 

|0 

IBR’I  2 

1  RX  1 

12  <  BR  1  16 
BR'  =  BR  -  12 
RA  =>  R2 


12  <  BR  i  16 
BR'  =  BR  -  12 
RA  =  R2 


16 


1  90 

1  RA  1 

1  RX  1  1 

ADDR  1 

8 

4 

4 

16 

1  94 

1  RA  1 

1  RX  M 

ADDR  1 

DHSCRIPTION:  The  contents  of  the  register  RA  are  stored  into  the  Derived  Addres.s.  DA. 
register  transfer  DESCRIPTION; 


[DA]  <--  (RA); 

REGISTERS  AFFECTED:  None 


STH.S  TIIX.ST.STI 
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5.46  Store  a  non  ncciitivc  constant. 
ADOR  MODE  MNEMONIC 


0  STC  N.ADDR 

DX  STC  N.AOOR.RX 


I  STC I  N.AOOR 

IX  STCI  N.AOOR.RX 


FORMAT /OPCODE 


8 

4 

4 

16 

1  91 

1  N  1 

RX  1  1 

ADOR  1 

8 

4 

4 

16 

1  02 

1  N  1 

RX  1  1 

ADOR  1 

DKSCRlPnON:  ITic  consunt  N,  where  N  is  an  integer  (0  <  N  <  15)  is  stored  at  the  Derived  Address.  DA.  For  the 
special  case  of  storing  zero  into  memory  the  mnemonics 

STZ  AOOR.RX  for  direct  addressing 
and  STZI  AOOR.RX  for  Indirect  addressing 


may  be  used.  In  this  special  case,  the  N  field  equals  0. 
transfer  DESCRIPTION! 


[OA]  <--  N.  where  0  1  N  1  16; 


registers  AFFECTED:  None 


79  Src.STCl.STZ.Siyj 
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5.47  Move  multiple  words,  mcinorv-lo-mcniorv. 

ADOR  MOUE  MNEMONIC  FORMAT/QPCODE 

8  4  4 

S  MOV  RA.RB  j  93  I  RA  I  RB  I 


IlFSC  KIPTtON:  This  instruction  allows  the  memory-to-memory  transfer  of  N  words  where  N  is  an  integer 

between  zero  and  2^^  - 1  and  is  represented  by  the  contents  of  RA  +  1.  fhe  contents  of  R  Bare  the 
address  of  the  first  word  to  be  transferred  and  the  contents  of  RA  arc  the  address  of  where  tne 
first  word  is  to  be  transferred.  After  each  word  transfer,  RA  and  RB  arc  incremented,  and  RA  +  1 
is  decremented. 

Note:  Any  pending  interrupts  are  honored  after  each  single  word  transfer  is  completed.  The  IC  points 

to  the  current  instruction  location  until  the  last  transfer  is  completed. 

RA  has  a  final  value  of  the  last  stored  address  plus  one;  RA  + 1  has  a  final  value  of  zero. 

RB  has  a  final  value  equal  to  the  address  of  the  last  word  transfered  plus  one. 

REGISTER  TRANSFER  DESCRIPTION: 


Step  1:  [(RA)]  <--  [(RB)]  if  (RA+1)  >  0;  Go  to  Step  4  otherwise; 

Step  2:  (RA)  <--  (RA)+1.  (RB)  <--  (RB)+1,  (RA+1)  (RA+1)-1; 

Step  3:  REPEAT  STEPS  1  and  2; 

Step  4:  Set  IC  to  next  instruction  address; 


AFFECTED: 


RA.  RA+1,  RB 


MOV 


SO 
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S.48  Double  Dictision  store. 

ADDR  MODE 

MNEMONIC 

FORMAT/OPCODE 

4  2 

2  8 

12  <  BR  i  15 
BR'  =  BR  -  12 
RA  RO 

B 

DSTB 

BR.DSPL 

1  0  |3 

IBR'I  DSPL  1 

4  2 

2  4  4 

12  <  BR  <  16 
BR'  =  BR  -  12 
RA  =  RO 

BX 

DSTX 

BR.RX 

1  4  |0 

|BR'|  3  1  RX  1 

DST 

DST 

RA.ADOR 

RA.AOOR.RX 

8 

4  4 

16 

u 

DX 

1  96 

i  RA  1  RX  1  1 

AODR  1 

8 

4  4 

16 

I 

IX 

OSTI 
DST  I 

RA.AODR 

RA.AOOR.RX 

1  98 

1  RA  1  RX  1  1 

ADDR  1 

UHSCRIPnON:  The  contents  of  registers  RA  and  RA  + 1  are  stored  at  the  Derived  Address.  DA,  and  DA  + 1, 
respectively 

register  TRARSflB  PLS.CAIEIIQM: 


fOA,  DA+1]  (RA.RA+1): 

REGISTERS  AFFECTED:  Nona 


81 
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5.49  Stoic  rcuistcr  through  mask. 


ADDR  MODE 

MNEMONIC 

FORMAT/OPCODE 

D 

SRM 

RA.AODR 

8 

4  4 

16 

DX 

SRM 

RA.ADDR.RX 

1  97 

1  RA  1  RX  1  1 

ADDR 

ni  'SCRII’'1'ION:  ITic  contents  of  register  RA  arc  stored  into  the  IJcrivcd  Address,  1)A.  through  the  mask  in  register 
RA  +  1. 1'or  each  position  in  the  mask  dial  is  a  one,  the  coi  responding  bit  of  register  RA  is  stored 
into  die  corresponding  bit  of  the  IM.  Kor  each  position  in  the  mask  that  is  a  zero  no  change  is 
made  to  the  corresponding  bit  stored  in  the  I9A. 

REGISTER  TRANSFER  DESCRIPTION: 

[DAJ  <--  {[DA]  t  (RA+1)}  V  {[RA]  t  [RA+1]}; 

(RA+1)  MASK,  (RAI  =  DATA; 
or  ,  equ i val ent ly , 

(RQ)  <--  [DA]: 

(R0)i  <--  (RA)(  if  (RA+1),  =  1  for  i  =  0.  1,  ...  15; 

[DA]  <--  (RQ); 

REGISFERS  AFFECTED:  None 


SRM 


82 
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5.50  SU)rc  imiliink-  rccistcfs. 
ADDR  MODE  MNEMONIC 


D  STM  N.AOOR 

DX  STM  N.AOOR. RX 


I  99  I  N  I 


I'he  contents  of  register  RO  are  stored  into  the  Derived  Address,  DA;  then  tlie  contents  of  R1 
arc  stored  into  DA  + 1 ; finally,  the  contents  of  RN  arc  stored  into  DA  ^  N  where  N  is  an 
integer.  0  <  N  <  15.  Effectively,  this  instruction  allows  the  transfer  of  (N  +  1)  words  from  the 
register  file  to  memory. 

REGISTER  TRANSFER  DESCRIPTION; 

[DA]  <-  (RO): 

[DA+1]  <--  (Rl); 

[DA+2]  <--  (R2); 


[DA+N]  <--  (RN)  0  <  N  i  16; 
REGISTERS  AFFECTED;  Non* 
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5.51  I'xicndcd  precision  ni),'it ina  Pt)int  store. 

ADDR  MOPE  MN LMO Ni£  FORMAT/OPCODE 

8  4  4  16 

D  EFST  RA.AOOR  - - - 

DX  EFST  RA.AOOR. RX  |  9A  |  RA  |  RX  |  |  AODH 


l)HSrRll>TION:  The  contents  ofregisters  RA.  RA+  I,  RA  +  2  are  stored  at  the  Derived  Address.  I  )A  I  )A  +  I,  and 
DA +  2. 

REGISTER  TRANSFER  DESCRIPTION: 


[DA.  DA+1.  DA+2]  <--  (RA.  RA+1,  RA+2): 


I 


\ 
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5.52  Store  inio  iipiK-r  bvtc. 

ADDR  MODE  MNEMONIC 


D  STUB  RA.ADOR 

DX  STUB  RA.ADOR, RX 


I  SUBI  RA.ADOR 

IX  SUBI  RA.ADOR.RX 


- ) 

/I  W Vl-ri. 

8 

4 

4 

16 

1  9B 

1  RA  1 

1  RX  1  1 

ADDR  1 

8 

4 

4 

16 

1  90 

1  RA  1 

1  RX  I  1 

ADDR  1 

DHSCRIPTION:  The  LSH  (lower  byte)  of  register  RA  is  stored  into  the  MSH  (upper  byte)  of  the  Derived  Address. 
DA.  Ihc  I  SH  (lower  byte)  of  the  DA  is  unchanged. 


REGISTER  TRANSFER  DESCRIPTION; 


[DA]o-7  <-  (RA)8.i6: 

REGISTERS  AFFECTED:  None 
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5.53  Store  into  lower  bvte. 

ADDR  MODE 

MNEMONIC 

FORMAT /OPCODE 

n 

STLB  RA.ADDR 

STLB  RA.ADDR. RX 

8 

4 

4 

16 

DX 

1  9C 

1  RA  1 

RX  1  1 

ADDR  1 

8 

4 

4 

16 

I 

IX 

SLBI  RA.ADDR 

SLBI  RA.ADDR.RX 

1  9E 

1  RA  1 

RX  1  1 

ADDR  1 

Dt'SCRIP'l'ION:  'Ihc  I.SH  (lower  byte)  of  register  kA  Is  stored  into  the  LSH  (lower  byte)  of  tlie  Oerived  Address, 
DA.  I’he  MSII  (upper  byte)  of  the  IM  Is  unchanged. 

REGISTER  TRANSFER  DESCRIPTION: 

[0A]a-i5  <■■  (RA)8.j5: 

REGISTERS  AFFECTED:  None 


sn.n.si.Hi 
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5.54  lAish  iiiiiliiplc  icgistcis  (wuu  ilie  stack. 

ADDR  MODE  MNEMONIC  f OHMAT/OPCODE 

8  4  4 


S  PSHM  RA.RB  |  9F  1  RA  |  RB  ) 


DKSCR IPTIQN:  For  RA  <  RB,  the  contents  of  RB  through  R  A  arc  pushed  onto  a  stack  in  memory  using  R15  as 
the  stack  pointer.  As  each  register  contents  arc  pushed  onto  the  memory  stack,  R15  is 
decremented  by  one  word  for  each  word  pushed.  On  completion,  R15  points  to  the  last  item  on 
the  stack,  the  contents  of  RA. 

For  RA  >  RB,  the  contents  of  RB  through  RO,  and  then  the  contents  of  R15  through  RA,  are 
pushed  onto  the  stack.  On  completion,  RIS  points  to  the  last  item  on  the  stack,  the  contents  of 
RA. 

In  both  eases,  successive  increasing  addresses  on  the  stack  correspond  to  successive  increasing 
register  addresses,  with  a  point  discontinuity  between  R15  and  RO  in  the  latter  case. 

HXAMPI.E:  PSHM  R3,R5  results  in 


(R15)  ->| 

(R3) 

1 

1 - 

1 

{R4) 

1 

1 

1 

(R6) 

1 

PSHM  R14,R2  results  in 

(R15)  -->1 

(R14) 

1 

1 

1 

(R16) 

1 

1 

1 

(RO) 

1 

1 

1 

(Rl) 

1 

1 

1 

(R2) 

1 
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RLGlblt  n  TRANSI  1  11  DL  SCIU  P T  lOM  : 

if  RA  <  RB  then 

for  i  -  0  thru  RB  -  RA  do 
beg  i  n 

(R15)  (R15)  -  1; 

[(R15)]  <  -  (RB  -  i); 
end ; 


el  se 


beg  i  n 
for  i 


for  i 


0  thru  RB  do 
beg  i  II 

(R15)  <--  (R15)  -  1: 
[(R15)]  <--  (RB  -  i); 
end ; 

0  thru  15  -  RA  do 
begin 

(R15)  <  -  (R15)  -  1; 
[(R15)]  <--  (R15  ~  i); 
end ; 


end ; 

REGISTERS  AETECTEU:  R15 


Mil  Sll)  y/bOI\  (IJSAf) 
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Sincio  i>h  1  'Muii  iiU'-UCi' 

^mi  MODI  MIUNIONit  lOKMAf/OPCOOti 


8 

4 

4 

R 

AR 

RA.RB 

1 

A1 

1  RA 

1  RB 

1 

4 

2 

2 

8 

12  <  BR  £  15 
BR'  =  BR  -  12 
RA  =  R2 

B 

AB 

BR.nSPt 

!  1 

10 

IBR'I 

!)SP1 

1 

4 

2 

2 

4 

4 

12  £  BR  <  15 
BR'  =  BR  -  12 
RA  =  R2 

BX 

ABX 

BR  .RX 

1  4 

|0 

IBR-  1 

4  1 

RX  1 

8 

4 

4 

ISP 

AISP 

RA,N 

1 

A2 

1  RA 

lN-1 

1 

1  <  N  <  16 

D 

OX 

RA.AOOR 

RA.ADOR.RX 

8 

4 

4 

16 

A 

1 

AO 

1  RA 

1  RX 

1  1 

ADDR  1 

8 

4 

4 

16 

IM 

AIM 

RA.OATA 

1 

4A 

1  RA 

1  1 

1  1 

DATA  1 

DESCRIP  I  ION:  The  Derived  Operand  (IX))  is  added  lo  the  contents  of  the  RA  register.  The  .esiilt  (a  2’s 

complement  sum)  is  stored  in  register  RA.  The  condition  status  (CS)  is  set  based  on  the  result  in 
register  R  A  and  carry.  A  fixed  point  overflow  occurs  if  both  operands  are  of  the  same  sign  and 
the  sum  is  of  opposite  sign. 
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FUiiJiLfii  IHANSFFR  OL-^' HUM  KIN; 

(RA)^  <--  (RA)'  +  DO; 

PI4  <--  1,  if  (RAu)'  =  DOo  and  (RAo)'  t  (RA^)^ 


(CS) 

<-- 

0010 

if 

carry  =  0 

and 

(HA) 

= 

n 

(CS) 

<-- 

0001 

if 

carry  =  0 

and 

(RA) 

\ 

0 

(CS) 

<-- 

0100 

if 

carry  =  0 

and 

(RA) 

> 

0 

(CS) 

<-- 

1010 

if 

carry  =  1 

and 

(RA) 

= 

0 

(CS) 

<-- 

1001 

if 

carry  =  1 

and 

(RA) 

< 

0 

(CS) 

<-- 

IIQQ 

if 

carry  =  1 

and 

(RA) 

> 

0 

REGISILRS  AFFECTED:  RA ,  CS ,  PI 


AK.AlLAliX  AM’  \.  M\1 


I ORHAT /OPCODE 
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5.56  Inciciiiciit  incmdrv  hv  a  nusitivc  integer. 


ADDR  MODE  MNEMONIC 


8  4  4  16 

0  INCM  N.ADDR  - - -  - 

OX  INCM  N.ADOR.RX  |  A3  |N-1  |  RX  |  |  AOOR 


DHSCRIHI  ION:  llic  contents  of  the  memory  location  specified  by  the  I'lerived  Address.  OA,  is  incremented  by  N. 

where  N  is  an  integer,  I  <  N  <  16.  'Iliis  instruction  adds  a  positive  constant  to  memory.  Ilie 
condition  status.  CS,  is  set  based  on  the  resulLs  of  the  addition  and  carry.  A  fixed  point  overflow 
(xrcurs  if  the  operand  in  memory  is  positive  and  the  result  is  negative.  The  memory  location 
specified  is  updated  to  contain  the  result  of  the  addition  process  even  if  a  fixed  point  overflow 
ix.'curs. 


REGISTER  TRANSFER  DESCRIPTION: 

[DA]^  s-  [DA]'  ♦  N.  where  1  <  N  <  16: 
PI,  1.  if  [OA]^  <  0  <  [DA]*; 


(CS)  ■ 

note 

if 

carry 

S 

0 

and 

[DA] 

= 

0 

(CSl 

t'l ,)  1 

if 

cai 

= 

0 

and 

[DA] 

< 

0 

(CS) 

V  too 

i  f 

carry 

a 

0 

and 

[DA] 

> 

0 

'CS)  ■ 

1)10 

If 

carry 

3 

1 

and 

[DA] 

c 

0 

(CS)  •  - 

1  0 ')  1 

if 

carry 

s 

1 

and 

[OA] 

< 

0 

(CS) 

11  O') 

If 

carry 

s 

1 

and 

[OA] 

> 

0 

RtGlSIt  RS 

ALii 

CS. 

PI 
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5M  iilc  precision  ahsoUitc  viiliic  of  register. 
AD OR  MODE  MNEMONIC 


R  ABS  RA.RB 


f ORMAI  'OPCODE 

8  4  4 


I  A4  I  RA  I  RB  I 


DI-SCRII^riON:  If  Die  sign  bit  of  the  Derived  Operand.  IX>  (i.e.,  tlie  sign  bit  of  register  RH).  is  a  one,  its  negative 
or  2's  comiUcmciU  is  stored  into  register  R.A.  However,  if  the  sign  bit  of  IX)  is  a  zero  it  is  stored, 
unchanged  into  RA  Ihe  condition  status.  CS,  is  set  based  on  the  result  in  regi  ,er  k 

Note  RA  may  equal  RH. 

The  absolute  value  of  a  number  witli  a  1  in  the  sign  bit  and  all  other  bits  zero  is  the  same  word, 
and  causes  fixed  point  overflow  to  (Kcur. 

REGISTER  TRANSFER  DESCRIPTION: 

PI4  <--  1.  exit,  if  DO  =  BOOOij; 

(RA)  <--  |D0| : 

(CS)  <--  0001  if  (RA)  =  BOOOje: 

(C5)  <--  0010  if  (RA)  =  0; 

(CS)  <--  0100  if  (RA)  >  0; 

REGISTERS  AFFECTED:  RA .  CS.  PI 


,\HS 
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5.58  Double  rucc'ision  ahsoliiic  v.iluc  iil'iceistcr. 

ADDR  MODI  HNEMQWIC 


FOKMAT /OPCODE 


DABS  RA.RB 


I  AS  I  RA  I  RB  I 


DKSCRIPHON:  If  the  sign  hit  of  the  double  precision  l>;rivcd  Operand  IX)  (i.c..  the  sign  bit  of  register  (RB, 

RB  + 1 )),  is  a  one,  its  negative  or  2’s  complement  is  stored  into  register  R A  and  RA  + 1,  such  that 
register  RA  contains  the  MSll  of  the  result.  However,  if  the  sign  bit  of  1)0  is  a  zero,  it  is  stored, 
urtchanged,  into  RA  and  RA  + 1.  Ihe  condition  sLitus,  CS,  is  set  based  on  tlic  result  in  register  RA 
and  RA+ 1. 

Note:  RA  may  equal  RB. 

The  absolute  value  of  a  number  with  a  1  in  the  sign  bit  and  all  other  bits  zero  is  the  same  word, 
and  causes  fixed  point  overflow  to  occur. 

REGISTER  1RAWSFER  DESCRIPTION: 

PI4  <--  1.  exit,  if  DO  =  8000  OOOOjg; 

(RA,RA+1)  <--  |00| : 

(CS)  <--  0001  if  (RA.RA+1)  =  8000  OOOOiel 

(CS)  <--  0010  if  (RA,RA+1)  =  0; 

(CS)  <--  0100  if  (RA.RA+l)  >  0; 

REGISTERS  AFFECTED:  RA.  RA+l .  CS.  PI 


MIL-STD-1760A  (USAF) 
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5.59  DnuhU-  nrccisioii  iiiiceer  add. 
ADPR  MODE  MWEMONIC 

R  OAR  RA.RB 


0  DA  RA.AOOR 

DX  OA  RA.AOOR, RX 


FORMAT/OPCODE 
8  4  4 

I  A7  I  RA  I  RB  I 

8  4  4  16 

I  A6  I  RA  I  RX  I  I  ADDR  | 


DHSCRIPTION:  'Ilic  double  precision  Derived  Operand  (IX))  is  added  to  the  contents  of  registers  RA  and  RA+  1. 

Ihe  result  (a  2's  complement  J2-bit  sum)  is  stored  in  registers  RA  and  RA  + 1.  Hic  MSH  is  in 
RA.  '1  he  condition  status  (CS)  is  set  based  on  the  double  precision  results  in  R.A  and  RA  + 1,  and 
carry.  A  fixed  point  overflow  occurs  if  both  operands  are  of  the  same  sign  and  tlic  sum  is  of 
opposite  sign. 

REGISTER  TRAMSFER  DESCRIPTION: 


(RA.RA+1)^  <--  (RA,RA+1)‘  +  DO; 

PI4  <--  1.  if  (RA(,)'  =  DOo  and  (RAq)'  (RAq)* 


(CS) 

<--  0010 

if 

carry 

•  0 

and 

(RA,RA+1) 

S 

0 

(CS) 

<--  0001 

If 

ca.''ry 

-  0 

and 

(RA,RA+1) 

< 

0 

(CS) 

<--  0100 

if 

carry 

=  0 

and 

(RA.RA+1) 

> 

0 

(CS) 

<--  1010 

if 

carry 

=  1 

and 

(RA.RA+l) 

s 

0 

(CS) 

<--  1001 

if 

carry 

=  1 

and 

(RA.RA+1) 

< 

0 

(CS) 

<--  1100 

if 

carry 

=  1 

a.nd 

(RA.RA+1) 

> 

0 

REGISTERS  AFFECTED 

r  RA. 

RA+1,  CS.  PI 

l)\R  DA 


94 
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5.60  l-lo.itine  point  add. 

AODR  MODE  MNEMONIC 

R  FAR  RA.RB 

B  FAB  BR.DSPL 


BX 


0 

OX 


FABX  BR.RX 


FA  R A, AODR 

FA  RA.AODR.RX 


FORMAT/OPCODE 


8 

4 

4 

1 

A9 

1  RA 

1  RB  1 

4 

2 

2 

8 

1  2 

|0 

IBR'I 

DSPL  1 

4 

2 

2 

4 

4 

1  4 

|0 

IBR'I 

8 

1  RX  1 

8 

4 

4 

I  A8  I  RA  I  RX  I  I 


12  <  BR  <  16 
BR'  =  BR  -  12 
RA  =  RO 


12  1  BR  <  16 
BR'  =  BR  -  12 
RA  =  RO 

16 


AODR  I 


DKSCRIFnON:  The  floating  point  Derived  Operand.  DO,  is  floating  point  added  to  the  contents  of  registers  RA 
and  RA  + 1.  The  result  is  stored  in  registers  RA  and  RA  + 1.  The  process  of  this  operation  is  as 
follows:  the  mantissa  of  the  number  witli  the  smaller  algebraic  exponent  is  shifted  right  and  the 
exponent  incremented  by  one  for  each  bit  shifted  until  the  exponents  arc  equal.  The  mantissas 
are  then  added.  If  the  sum  overflows  die  24-bil  mantissa,  then  the  sum  is  shifted  right  one 
position,  the  sign  bit  restored,  and  the  exponent  incremented  by  one.  If  the  exponent  exceeds 
7F,  j  as  a  result  of  this  incrementation,  overflow  occurs  and  the  operation  is  terminated.  If  the 
sum  does  not  result  in  exponent  overflow,  the  result  is  normalized.  If  in  the  normalizadon  process 
the  exponent  is  decremented  below  80]^,  then  underflow  occurs  and  a  zero  is  inserted  for  the 
result. 


95  FAR.I  AII.I  AUX.I'A 
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REGISTER  TRANSFER  DESCRIPTION: 


n  =  EA  -  FO: 

MO  <--  MO  Shifted  Right  Arithmetic  n  positions,  if  n  >*0  and  MA  X  0: 

MA  <--  MA  Shifted  Right  Arithmetic  -n  positions,  EA  <--  EO,  if  n  <  0  and  MO  ^  0 
MA  <--  MA  +  MO; 

MA  <--  MA  Shifted  Right  Arithmetic  1  position,  MAg  <--MAq,  EA  <--  EA+1, 
if  OVM  =  1; 


PI3 

<- 

1,  EA  <-- 

7Fi6.  MA 

<-- 

7FFF 

FF16. 

exit. 

if 

EA 

> 

7F,6 

and 

MAq  =  0; 

PI3 

<-- 

1,  EA  <-- 

7F,6.  MA 

<-- 

8000 

OO16. 

exit. 

if 

EA 

> 

7F,6 

and 

MAq  =  1; 

EA,  MA  <--  normalized  EA,  MA; 


Pie  < 

-- 

1,  EA 

<-- 

0,  MA  <--  0, 

if  EA  <  80ig 

(CS) 

<- 

-  0010 

if 

(RA,RA+1)  ' 

0; 

(CS) 

<- 

-  0001 

if 

(RA,RA+1)  < 

0; 

(CS) 

<- 

-  0100 

if 

(RA,RA+1)  > 

0; 

REGISTERS  AFFECTED:  RA,  RA+1,  CS.  PI 


FAR.I-An.FAlIX.FA 


% 
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.•).() I  I  pigiMoii  Ild.iiKip.  ijdini  add. 

AOOR  MOOK  MNEMONIC 


R  EFAR  RA.RB 


D  EFA  RA.AOOR 

OX  FFA  RA.AOOR. RX 


MU -STD-1750A  (USAF) 
2  July  1980 


lORMAI/ORCODL 

8  4  4 


I  AB  I  RA  I  RB  I 


8  4  4  16 


I  AA  I  RA  I  RX  I  I  AOOR 


UFSCRII^l  ION:  'Fhc  extended  precision  floating  point  Derived  Operand.  IXD,  is  extended  floating  point  added  to 
the  contents  of  register  RA,  RA  + 1,  and  RA  +  2.  'Fhe  result  is  stored  in  register  RA,  RA  +  1,  and 
R  A  +  2.  'llie  process  of  this  operation  is  as  follows:  the  mantissa  of  the  number  with  tlie  smaller 
algebraic  exponent  is  shifted  right  and  the  exponent  is  incremented  by  one  for  each  bit  shifted. 
When  the  exponents  arc  equal,  the  mantissas  are  added.  If  the  sum  overflows  tlie  39-bit  mantissa, 
then  the  sum  is  shifted  right  one  position,  die  sign  bit  restored,  and  the  exponent  is  incremented 
by  one.  If  the  exponent  exceeds  7Fig  as  a  result  of  this  incrementation,  overflow  occurs  and  the 
operation  is  terminated.  If  the  sum  does  not  result  in  exponent  overflow,  the  result  is  nonnali^ed. 
If  in  the  normalization  process  the  exponent  is  decremented  below  SOi^,  then  underflow  occurs 
and  a  zero  is  inserted  for  the  result. 

REGISTER  TRANSFER  DESCRIPTION: 

n  =  EA  -  DO; 

MO  <--  MO  Shifted  Right  Arithmetic  n  positions,  if  n  >  0  and  MA  ^  0; 

MA  <--  MA  Shifted  Right  Arithmetic  -n  positions,  EA  <--  EO,  if  n  <  0  and  MO  ^  0; 

MA  <--  MA  +  MO; 

MA  <--  MA  Shifted  Right  Arithmetic  1  position,  MAq  <--MA5,  EA  <--  EA+1, 
if  OVM  =  1: 


PI3  <-- 

1. 

EA  <-- 

7Fi6. 

MA  <-- 

7FFF 

FF 

ffff,6. 

exit. 

if 

EA  > 

7Fi6 

and 

MAo  = 

0; 

PI3  <- 

1. 

EA  <-- 

7Fi6. 

MA  <-- 

8000 

00 

OOOOjQ* 

exit , 

if 

EA  > 

7Fi6 

and 

MAo  = 

1: 

EA,  MA  <--  normalized  EA.  MA; 


Ph  < 

-- 

1.  EA 

<-- 

0.  MA 

<--  0, 

if  EA  < 

SOi#; 

(CS) 

<- 

-  0010 

if 

(RA, 

RA+1, 

RA+2)  * 

0; 

(CS) 

<- 

-  0001 

if 

(RA, 

RA+1, 

RA+2)  < 

0; 

(CS) 

<- 

-  0100 

if 

(RA. 

RA+1, 

RA+2)  > 

0: 

REGISTERS  AFFECTED:  RA.  RA+1,  RA+2,  CS,  PI 


97 


EFAR.KFA 
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Mil -STD-1760A  (USAF) 

2  July  1980 

5.6?.  I  loniliu'.  pimit  .ihsdiiitc  Naluouf  register. 

ADUR  MODE  MNEMONIC  FORMAT /OPCODE 

8  4  4 

R  FABS  RA.RB  |  AC  |  RA  |  RB  | 


DHSCRIPMON:  If  the  sign  bit  of  the  mantissa  of  the  Derived  Operand,  I XJ  (i.e..  the  contents  ofregisters  RH  and 
RI1+  1),  is  a  one,  its  lloating  point  negative  is  stored  in  registers  RA  and  RA  4  1.  The  negative  of 
1  )0  is  coiiipiited  by  taking  the  2's  complement  of  the  mantissa  and  leaving  the  exponent 

unchanged.  l  Accptiotts  to  this  are  negative  powers  of  two;  -1.0  x  ?*’,  -1.0  x  ?' .  ITie  absolute 

value  of  these  are:  0.5  x  0.5  x  2^ . ;  in  other  words,  the  IXT  mantissa  is  shifted  logically  right 

Opc  position  and  the  exponent  incremented.  A  lloating  point  overflow  shall  occur  if  IX)  is  the 
smallest  negative  number,  -1.0  x  2*^^.  If  the  sign  bit  of  DO  is  a  /cro.  it  is  stored  unchanged  into 
R.A  and  RA  -E  I.  The  condition  status,  CS.  is  set  based  on  the  result  in  register  RA  and  RA  -t- 1. 

Note:  RA  may  equal  RR. 

DO  is  assumed  to  be  a  notmali/cd  number  or  flrrating  point  zero. 

REGISTER  TRANSFER  DESCRIPTION: 


EA  <-- 

EA-n, 

MA 

< 

--  4000  00,6. 

if 

MO  = 

8000 

OOie: 

PI3  <- 

-  1.  EA 

< 

-- 

7Fi6. 

MA  <-- 

7FFF  FF, 

6.  exi 

it.  i 

EA  <-- 

EO.  MA 

< 

-- 

-MO. 

if  MO  < 

0. 

MO  y 

8000 

00,5; 

EA  <-- 

EO.  MA 

< 

-- 

MO. 

if  MO  > 

0; 

(CS)  < 

--  0010 

if 

(RA 

.  RA-H)  = 

0: 

(CS)  < 

--  0001 

if 

(RA 

.RA-rl)  < 

0; 

(CS)  < 

--  0100 

if 

(RA 

.RA+1)  > 

0; 

REGISTERS  AFF 

EC 

TED:  RA,  RA+1, 

CS 

.  PI 

EARS 


')X 

iJO 


M1L-STD-1760A  (USAF) 
2  July  1980 


5.6,1  Single  nrcc^ioii  iuK'gcr  subtract. 

AODR  MODE  MWFMOWIC  FORMAT/OPCODE 


8 

4 

4 

R 

SR 

RA.RB 

1 

B1 

1  RA 

1  RB  1 

4 

2 

2 

8 

12  <  BR  <  15 
BR’  =  BR  -  12 
RA  =  R2 

B 

SBB 

BR.OSPL 

1  1 

|1 

|BR-| 

DSPL  1 

4 

2 

2 

4  4 

12  <  BR  <  15 
BR'  =  BR  -  12 
RA  =  R2 

BX 

SBBX 

BR.RX 

1  4 

|0 

IBR’l 

5  1  RX  1 

8 

4 

4 

ISP 

SISP 

RA,N 

1 

B2 

1  RA 

|N-1  1 

1  <  N  <  16 

0 

OX 

C 

RA.AOOR 

RA.AOOR.RX 

8 

4 

4 

16 

s 

1 

BO 

1  RA 

1  RX  1  1 

ADDR  1 

8 

4 

4 

16 

IM 

SIM 

RA.OATA 

1 

4A 

1  RA 

1  2  1  1 

DATA  1 

tJHSCR  IP  I  ION :  Tlic  Derived  Operand  (fX))  is  subtracted  from  the  contents  of  the  RA  register.  The  result,  a  2‘s 
complement  difference,  is  stored  in  RA.  Ihe  condition  status  (CS)  is  set  based  on  the  result  in 
register  RA  and  carry.  A  fixed  point  overflow  occurs  if  both  operands  arc  of  opposite  signs  and 
the  derived  operand  is  tlic  same  as  the  sign  of  the  difference. 


90 


SR.SIUl.SmiX.SISI'.S.SIM 

h 


I 
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REGISTER  TRANSFER  DESCRIPriON: 


(RA)^  <--  (RA)'  -  00.  i.e.,  (RA)  -  DO  means  {(RA)  +  00}  +  1; 


PI4  < 

-- 

1.  if 

(RAo) 

’  i  DOo  and  (RAg)^  = 

DO, 

(CS) 

<- 

-  0010 

if 

carry  =  0 

and 

(RA) 

= 

0 

(CS) 

<- 

-  0001 

if 

carry  =  0 

and 

(RA) 

< 

0 

(CS) 

<- 

-  0100 

if 

carry  =  0 

and 

(RA) 

0 

(CS) 

<- 

-  1010 

if 

carry  -  1 

and 

(RA) 

= 

0 

(CS) 

<- 

-  1001 

if 

carry  =  1 

and 

(RA) 

< 

0 

(CS) 

<- 

-  1100 

if 

carry  =  1 

and 

(RA) 

> 

0 

!i 


REGISTERS  AFFECTED:  RA,  CS,  PI 


M11.-S1D-1750A  (USAf) 
2  July  1980 


5.64  IXvH'iticin  nicmdiv  bv  a  nositivc  inicecr. 

ADDR  MOD F  MNEMONIC  FORHAT/OPCODE 


8  4  4  16 

D  DECM  N.AODR  -  - 

DX  OECM  N.AOOR.RX  |  B3  |N-1  |  RX  j  |  AODR 


DK.SCRIP'I  ION,  llic  contents  of  the  memory  location  specified  by  the  Derived  Address.  DA,  arc  decremented  by 
N  where  N  is  an  integer,  1  <  N  <  16.  'Ihis  is  the  equivalent  of  a  "subtract- from-mcinory 
instruction".  The  condition  status,  CS,  is  set  based  on  die  results  of  the  subtraction  and  carry.  A 
fixed  point  overflow  (xcurs  if  the  operand  in  memory  is  negative  and  the  result  is  positive.  Ihe 
memory  location  specified  is  updated  to  contain  the  result  of  the  subtraction  process  even  if  a 
fixed  point  overflow  occurs. 

REGISTER  TRANSFER  DESCRIPTION: 


[DA]^  <--  [DA]*  -  N.  whore  1  i  N  1  13; 
PI4  <-  1,  if  [DAfl]*  <  0  <  [DA^]^; 


(CS) 

<--  0010 

if 

carry 

= 

0 

and 

[DA] 

= 

0 

(CS) 

<--  0001 

if 

carry 

0 

and 

[DA] 

< 

0 

(CS) 

<--  0100 

if 

carry 

= 

0 

and 

[DA] 

> 

0 

(CS) 

<--  1010 

if 

carry 

a 

1 

and 

[DA] 

0 

(CS) 

<--  1001 

if 

carry 

s 

1 

and 

[DA] 

< 

0 

(CS) 

<--  1100 

if 

carry 

= 

1 

and 

[DA] 

> 

0 

S&6.t5TTRS  AFFECTED 

CS. 

PI 

101 


DKCM 
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5.85  Single  nrccision  ncuatc  rceistcr. 

ADDR  MODE  MNEMONIC  FORMAT /OPCODE 

8  4  4 

R  NEC  RA.RB  |  B4  |  RA  |  RB  | 

DHSCRIFFION:  ll'ic  negative  (i.c.,  the  2’s  complement)  of  the  Derived  Operand,  IK)  (i.c.,  the  contents  of  register 
RB),  is  stored  into  register  RA.  Ihc  condition  status,  CS,  is  set  based  on  the  result  in  register  R  A. 

Note:  The  negative  of  zero  is  zero. 

llie  negative  of  a  number  with  a  I  in  the  sign  bit  and  all  other  bits  zero  is  the  same  word,  and 
causes  fixed  point  overflow  to  occur. 

REGISTER  TRANSFER  DESCRIPTION: 

PI4  <--  1,  exit,  if  DO  =  8000|g; 

(RA)  < - DO; 

(CS)  <--  0010  if  (RA)  =  0: 

(CS)  <--  0001  if  (RA)  <  0; 

(CS)  <--  0100  if  (RA)  >  0; 

REGISTERS  AFFECTED:  RA,  CS .  PI 


MIL-STD-1750A  (USAF) 
2  July  1980 

5.66  iJoiihIc  nrccision  ncc.itc  register. 

ADDR  MODE  MNEMONIC  EORMAT/OPCODE 

8  4  4 

R  ONEG  RA.RB  |  86  |  RA  |  RB  | 


DHSCRIKnON:  The  negative  (i.e.,  the  2’s  complement)  of  the  Derived  Operand,  DO  (i.e.,  the  contents  of  register 
RB  and  RB  + 1),  is  stored  into  register  RA  and  RA  + 1  such  that  register  RA  contains  the  MSH  of 
the  result.  ITie  condition  status,  CS,  is  set  ba.scd  on  tlie  result  in  register  RA  and  RA+ 1. 

Note:  The  negative  of  zero  is  zero. 

Ihe  negative  of  a  number  with  a  1  in  the  sign  bit  and  all  other  bits  zero  is  the  same  word,  and 
causes  fixed  point  overflow  to  occur. 

REGISTER  TRANSFER  DESCRIPTION; 

PI4  <--  1,  exit,  if  DO  =  8000  0000,#; 


(RA,RA+1)  <--  -DO; 


(CS) 

<-- 

0010 

if 

(RA,RA+1) 

=  0; 

(CS) 

<-- 

0001 

if 

(RA,RA+1) 

<  0; 

(CS) 

<-- 

0100 

if 

(RA,RA+1) 

>  0: 

REGISTERS  AFFECTED:  RA,  RA+1 ,  CS.  PI 


103 


DNFX3 
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MIL-STO-1750A  (USAF) 

2  July  1980 

5.67  noubic  precision  integer  siihtract. 
ADDR  MODE  MNEMONIC 


R  DSR  RA.RB 


D  OS  RA.ADOR 

DX  OS  RA.ADOR, RX 


rORMAT/OPCODE 
8  4  4 

I  87  I  RA  I  RB  I 

8  4  4  16 

I  B6  I  RA  I  RX  I  I  ADDR 


llKSCRIFriON:  The  double  precision  IJcrived  Operand.  IX).  is  subtracted  from  the  contents  of  registers  RA  and 
RA  +  1.  Hie  results,  a  2’s  complement  .l.'’-bit  diftercncc,  is  stored  iit  registers  RA  and  RA  +  1.  Ihe 
MSH  is  RA.  Ihe  condition  status  (CS)  is  set  based  on  the  double  precision  results  in  RA  and 
RA+  l.and  carry.  A  fixed  point  overflow  occurs  if  both  operands  arc  of  I'ppositc  sign  and  the 
derived  operand  is  the  s;tme  as  the  sign  of  tltc  difference. 

REGISTER  TRANSFER  DESCRIPTION: 

(RA.RA+1)2  <--  (RA.RA+1)*  -  DO,  i.e.,  (RA.RA+1)  -  DO  means  {(RA,RA+1)  +  DO)  +  1; 


PI4  <--  1.  if  (RAq)*  a  DOo  and  (RAo)^  =•  DO^ 


(CS) 

<--  0010 

if 

carry 

s 

0 

and 

(RA.RA+1) 

= 

0 

(CS) 

<--  0001 

if 

Carry 

= 

0 

and 

(RA.RA+1) 

< 

0 

(CS) 

<--  0100 

if 

carry 

s 

0 

and 

(RA.RA+1) 

> 

0 

(CS) 

<--  1010 

if 

carry 

= 

1 

and 

(RA.RA+1) 

0 

(CS) 

<--  1001 

if 

carry 

s 

1 

and 

(RA,RA+1) 

< 

0 

(CS) 

<--  1100 

if 

carry 

= 

1 

and 

(RA.RA+1) 

> 

0 

REGISTERS  AFFECTED: 

RA. 

RA+1,  CS.  PI 

DSR.DS 


104 

136 


.f 


I  li Miini:;  puini  snbinii.1. 
AODK  MULIL  MNLMONIC 


fORMAI /OPCODE 


8 

4 

4 

R 

f5R 

RA.RB 

1 

B9 

1  RA 

1  RB  1 

4 

2 

2 

8 

B 

FSB 

BH.OSRL 

1  2 

|1 

IBR'I 

DSPL  1 

4 

2 

2 

4  4 

BX 

FSBX 

BR.RX 

1  4 

|0 

IBR'I 

9  1  RX  1 

C 

F  S 

RA.AOOR 

8 

4 

4 

12  <  BR  <  15 
BR’  =  BR  -  12 
RA  =  RO 


12  <  BR  <  15 
BR'  =  BR  -  12 
RA  =  RO 


ux 


FS  RA.AOOR.RX 


I  B8  I  RA  i  RX  I  I 


16 

ADDR 


DKSCkItM  ION  .  Ihc  floating  point  Otrived  Operand.  IX).  is  floating  point  subtracted  from  the  contents  of 

registers  RA  and  RA  +  I .  Ihe  result  is  stored  in  registers  RA  and  RA  + 1.  llic  process  of  this 
operation  is  as  follows:  the  mantis&t  of  the  number  with  the  smaller  algebraic  exponent  is  shifted 
nght  and  the  exponent  incremented  by  one  for  each  bit  shifted  until  the  exponents  arc  equal.  The 
mantissa  of  the  DO  is  then  subtracted  from  (R  A.R  A  +  1 ).  If  the  difference  overflows  tlic  24-bit 
mantiss.1,  then  it  is  shifted  right  one  position,  the  sign  bit  restored,  and  the  exponent  incremented 
by  one.  If  the  exponent  exceeds  7Fjft  as  a  result  of  this  incrementation,  overflow  occurs  and  the 
operation  Is  terminated.  If  the  sum  docs  not  result  in  exponent  overflow,  the  result  is  normalized. 
If  during  the  normalization  process  the  exponent  is  decremented  below  80)^,  then  underflow 
occurs  and  a  zero  is  inserted  for  the  fcsult. 


M[L-STD-1750A  (USAF) 

2  July  1980 

lirr.ISTER  TRANSFER  DESCRIPTION: 
n  =  EA  -  EO; 


MO  <-- 

MO 

Sh  i  f  ted 

R  ight 

Arithmetic 

n  pos i t  ion5 , 

i  f  n  > 

0  and  MA 

*  0; 

MA  <-- 

MA 

Sh  i  fled 

Right 

Arithmetic 

-n  positions 

.  EA  <-- 

EO.  if 

n  <  0  and 

MA  <-- 

MA 

-  MO: 

MA  <-- 

MA 

Sh i f  ted 

Right 

Ar ithmet  ic 

1  position. 

MAg  <--MAg.  EA  <- 

--  EA+1. 

if 

OVM  =  1: 

PI3  <- 

-  1. 

EA  <-- 

7^16- 

MA  <--  7FFF 

FFjg.  exit. 

if  EA  > 

7F  ,g  and 

MAg  =  0: 

PI3  <- 

-  1. 

EA  <-- 

7Fi6- 

MA  <--  8000 

OOjg.  exit. 

if  EA  > 

7Fjg  and 

MAg  =  1; 

EA,  MA  <--  normalized  EA,  MA; 

Pig  <--  1.  EA  <--  0.  MA  <--  0.  if  EA  <  SOig; 

(CS)  <--  0010  if  (RA.RA+1)  =  0; 

(CS)  <--  0001  if  (RA.RA+1)  <  0; 

(CS)  0100  if  (RA.RA+1)  >  0; 

REGISTERS  AFFECTED:  RA.  RA+l,  CS .  PI 


FSR.FSH.ISIlX.FS 


lOf. 
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HU-S7D-  1750A  (USAF) 
2  July  1980 


5.09  l-Atciiclod  nrccision  llo.itifm  noint  subtract. 
AO  DR  MOOF.  MNFMONIC 


R  EFSR  RA.RB 


0  EFS  RA.AODR 

DX  EFS  RA.AODR, RX 


FORMAT/QRCOOE 

8  4  4 

I  BB  I  RA  I  RB  I 

8  4  4  16 

I  BA  I  RA  I  RX  I  I  AOOR  | 


DF-.SCKIP  I'ION:  llic  extended  precision  Floating  point  Derived  Operand.  FX).  is  extended  floating  point 

subtracted  from  the  contents  of  registers  RA.  RA  +  1.  and  RA  +  2.  The  result  is  stored  in  registers 
RA,  RA  + 1,  and  RA  +  2.  The  process  of  tliis  operation  is  as  follows;  the  mantissa  of  die  number 
with  the  smaller  algebraic  exponent  is  shifted  right  and  the  exponent  is  incremented  by  one  ‘or 
each  bit  shifted.  When  tlie  exponents  are  equal,  the  mantissas  are  subtracted.  If  the  difference 
overflows  the  39-bit  mantissa,  then  the  difference  is  shifted  right  one  position,  the  sign  bit 
restored,  and  die  exponent  is  incremented.  If  the  exponent  exceeds  71')^  as  a  result  of  this 
incrementation,  overflow  occurs  and  die  operation  is  terminated.  If  the  sum  does  not  result  in 
exponent  overflow,  the  result  is  normali/cd.  If  during  the  normali/.atiun  process  the  exponent  is 
decremented  below  80^J,  then  underflow  occurs  and  a  zero  is  inserted  for  the  result. 

REGISTER  TRANSFER  DESCRIPTION: 

n  =  EA  -  EO; 

MO  <--  MO  Shifted  Right  Arithmetic  n  positions,  if  n  >  0  and  MA  ^  0; 

MA  <--  MA  Shifted  Right  Arithmetic  -n  positions,  EA  <--  EO,  if  n  <  0  and  MO  ^  0; 

MA  <--  MA  -  MO; 

MA  <--  MA  Shifted  Right  Arithmetic  1  position.  MAq  <--MAq,  EA  <--  EA+1 , 
if  OVM  =  1; 


PI3 

<-- 

1. 

EA  <--  7F,6 

.  MA 

<-- 

7FFF 

FF 

FEEF16. 

exit. 

if 

EA  > 

7Ei6 

and 

MAq  = 

0; 

PI3 

<-- 

1, 

EA  <--  7F,6 

,  MA 

<-- 

8000 

00 

0000,6. 

exit. 

if 

EA  > 

7F,6 

and 

MAq  » 

1: 

EA. 

MA 

<-- 

normal ized 

EA. 

MA; 

PIr  <- 


1,  EA  <--  0,  MA  <--  0.  if  EA  <  80 


I6> 


(CS)  <--  0010  if  (RA,  RA+l,  RA+2)  =  0 
(CS)  <--  0001  if  (RA,  RA+l,  RA+2)  <  0 
(CS)  <--  0100  if  (RA,  RA+l.  RA+2)  >  0 


REGISTERS  AFFECTED:  RA,  RA+l,  RA+2.  CS.  PI 
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3.70  I'lo.itiiiu  point  negate  rcci-'tcr. 
ADOR  MODI  MNEMONIC 

R  FNEG  RA.RB 


FORMAT/OPCODE 

8  4  4 


I  BC  I  RA  I  RB  I 


DISCRII*’!  ION:  l^ic  24-bil  iti.iiuissa  of  the  Derived  Operand,  IX),  i.e..  the  floating  point  number  in  registers  Rll 
and  RI1+  1,  is  .Ts  complemented.  I’hc  exponent  remains  unchanged.  Ibe  result,  the  negative  of 
the  origina.  number,  is  stored  in  RA  and  RA  t  1.  Ibe  2  s  complement  of  a  floating  point  /  ro  is  ,a 
floating  point  /.ero.  (Exceptions  to  this  are  all  porvers  of  two.  -1.0  x  2"  and  0.3  x  2"  ' :  i  e  .  when  die 
mantissa  is  either  XOOO  00,,,  or  4000  OOj^.  Ibe  negation  of  0.5  x  2'''  is  -1.0  x  2"  '  :  i  c  the  mantissa  is 
shifted  left  one  position  and  the  exponent  dccrenienicd  by  one.  Conversely,  Die  negation  of  1,0  x 
2"  is  0.5  X  2"  *■ ' ;  i  e.,  tlte  mantissa  is  shifted  right  one  position  and  the  exponent  is  increineiued  bv 
one.  A  floating  point  overflow  (xrcurs  for  the  negation  of  the  smallest  negative  number,  - 1  0  x 
2*'^  A  floating  point  underflow  occurs  for  the  negation  of  the  smallest  positive  mimtier,  0.5  x  2 
12S,  and  causes  the  result  to  be  zero,  'Ibe  condition  status,  CS,  is  set  based  on  Oie  result  in  registers 
RA  and  RA-t-1, 

Note:  RA  may  equrd  RR, 

REGISTER  TRANSFER  JESCRIPTION: 

PIj  <--  1.  £A  <--  7Fi3,  mo  <--  7FFF  FFjg,  exit,  if  DO  =  8000  007Fi6; 

PTg  <--  1.  EA  <--  0.  MA  0.  exit,  if  00  =  4000  0080, a.- 

EA  <--  EO+1,  MA  <--  4000  00,6,  ^0  =  8000  00,6; 

EA  <--  EO-1.  MA  <--  8000  00,6.  if  MO  =  4000  00,9; 

EA  <--  EO.  MA  <--  -MO,  if  MO  i  8000  OOjg  or  4000  00, g; 

(CS)  <--  0010  if  (RA.RA+l)  =  0 

(CS)  <--  0001  if  (RA.RA+1)  <  0 

(CS)  <--  0100  if  (RA,RA+1)  >  0 


REGISTERS  AFFECTED:  RA .  RA+1,  CS,  PI 


bNlEfi 
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S  ’’  1  Single  piv.\is»iH  iiiKTyr  iimUipIv  ’aiiU  lA-hit  niotUii  1. 


ADDR  MODE 

MNEMONIC 

rORMAT/OPCODE 

8 

4 

4 

R 

MSR 

RA.RB 

1  Cl 

1  RA  1 

1  RB  1 

8 

4 

4 

ISP 

MISP 

RA,N 

1  C2 

1  RA  1 

|N-1  1 

1  i  N  <  16 

8 

4 

4 

ISN 

MISN 

RA.N 

1  C3 

1  RA  1 

|N-1  1 

1  <  N  <  16 

D 

MS 

RA.AODR 

8 

4 

4 

16 

OX 

MS 

RA.ADOR.RX 

1  CO 

1  RA  1 

1  RX  1 

1  ADDR  1 

8 

4 

4 

16 

IM 

MSIM 

RA.DATA 

1  AA 

1  RA  1 

1  A  1 

1  DATA  1 

DF.SCRIPTION:  The  Derived  Operand,  DO,  is  multiplied  by  the  contents  of  register  RA,  The  of  the  result,  a 
16-bit.  2’s  complement  integer,  is  stored  in  register  RA.  The  Condition  Status,  CS,  is  set  based  on 
the  result  in  register  RA.  A  fixed  point  overflow  occurs  if  (1)  both  operands  are  of  the  same  sign 
and  the  MSH  of  the  product  is  not  zero,  or  the  sign  bit  of  the  LSH  is  not  zero,  or  (2)  if  the 
operands  are  of  opposite  sign  and  the  MSH  of  the  product  is  not  FFI-'Fjg,  or  the  sign  bit  of  the 
LSH  is  not  one.  A  fixed  point  overflow  docs  not  occur  if  either  of  the  operands  is  zero. 

REGISTER  TRANSFER  DESCRIPTION: 

(RQ.  RO+1)  <--  (RA)‘  X  DO; 

(RA)^  <--  (RQ+l); 

PI4  <--  1.  if  {(RAq)’  =  OOq  and  {(RQ)  »<  0  or  (RQ+Iq)  =  1}}  or 
{(RAo)^  ^  OOo  and  {(RQ)  ¥  FFFFie  (RQ+lo)  =  A”*! 

{(RA)‘  ¥  0  and  DO  ¥  01}; 


(CS) 

<-  - 

0010 

if 

(RA) 

“  0; 

(CS) 

<-- 

0001 

if 

(RA) 

<  0; 

(CS) 

0100 

if 

(RA) 

>  0: 

REGISTERS  AFFECTED:  RA,  CS,  PI 
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5.72  Sir 


ision  integer  nnil tinlv  with  -12-hit  orodurt. 


ADDR  MODE  MNEMONIC 


8 

4 

4 

R 

MR 

RA,RB 

1 

C5 

1  RA 

1  RB  1 

4 

2 

2 

8 

B 

MB 

BR.DSPL 

1  1 

|2 

IBR'I 

DSPL  1 

4 

2 

2 

4 

4 

BX 

MBX 

BR.RX 

1  4 

10 

IBR'I 

6 

1  RX  1 

12  <  BR  <  15 
BR'  =  BR  -  12 
RA  =  R2 

12  <  BR  i  16 
BR'  =  BR  -  12 
RA  =  R2 

16 


M  RA.ADOR 

M  RA.ADOR, RX 


MIM  RA.DATA 


1  C4 

1  RA  I 

1  RX  1  1 

ADDR  1 

8 

4 

4 

16 

1  4A 

1  RA  1 

1  3  1  1 

DATA  1 

DKSCRIFIION:  The  Derived  Operand,  IX),  is  multiplied  by  the  contents  of  register  RA.  The  result,  a  32-bit,  2’s 
complement  integer,  is  stored  in  registers  RA  and  RA+ 1  with  the  MSH  of  die  product  in  register 
RA.  Ihe  Condition  Status,  CS.  is  set  based  on  the  result  in  registers  RA  and  RA  + 1. 

SPF.CIAL  CASH:  DO  =  (RA)  =  80(X)  (the  largest  negative  number),  Uien  DO  x  (RA)  =  4(XX)  0000. 

REGISTER  TRANSFER  DESCRIPTION; 

(RA.RA+1)  <--  (RA)  X  DO: 

(CS)  <--  0010  if  (RA.RA+1)  =  0; 

(CS)  <--  0001  if  (RA,RA+1)  <  0; 

(CS)  <--  0100  if  (RA,RA+1)  >  0; 

REGISTERS  AFFECTED:  RA,  RA+1 .  CS 
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5.71  Doiihic  DicciMoii  iiiict’cr  iiuiUiiily. 
fiDOR  MOUE  MNEMONIC 


I ORHAT /OPCODE 


OMR  RA , RB 


I  C7  I  RA  I  RB  I 


4  4 


RA.ADDR 

RA.AODR.RX 


I  C6  I  RA  I  RX  I  I 


DF.SCRIP'l'ION:  The  double  precision  Derived  Operand,  DO,  a  32-bit  2’s complement  number,  is  multiplied  by 
the  contents  of  registers  RA  and  RA  -H,  a  .32-bit  2's  complement  number,  with  tlie  MSH  in  RA. 
'Ihe  l  .SH  of  the  product  is  retained  in  RA  and  RA-E  1  as  a  32-bit.  2‘s  complement  number.  The 
MSH  is  lost  Tlic  Condition  Status.  CS,  is  set  based  on  tlic  double  precision  result  in  registers  RA 
and  RA-eI.  A  fixed  point  overflow  occurs  if  (I)  both  operands  are  of  tlie  same  sign  and  the  MSH 
of  the  product  is  not  zero,  or  the  sign  bit  of  the  I  .SH  is  not  zero,  or  (2)  if  the  operands  are  of 
opposite  sign  and  the  MSH  of  the  product  is  not  Fl-IT-  FFFFk,  or  the  sign  bit  of  the  l.SH  is  not 
one.  A  fixed  point  overflow  docs  not  occur  if  cither  of  the  operands  is  zero. 


TRANSFER 


(R0.RQ+1.R0+2.RQ+3)  (RA.RA+1)*  x  DO; 

(RA.RA+1)2  <--  (R0+2.RQ+3); 


PI4  <--  1.  if  {(RAo)‘  *  OOfl  and  {(RQ.RO+1)  0  or  (RO+2o)  =  1))  or 

{(RAo)‘  *  OOfl  and  {(RQ.RQ+1)  *  FFFF  FFFFjj  or  (RQ+2o)  =  0} 
{(RA)‘  *  0  and  DO  i  0}}; 


(CS)  <--  0010  if  (RA.RA+1)  =  0 
(CS)  <--  0001  if  (RA.RA+l)  <  0 
(CS)  <--  0100  if  (RA.RA-t-l)  >  0 


REGISTERS  AFFECTED:  RA,  RA+l,  CS.  PI 


DMR.DM 
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5.74  Hoaiina  noint  multiDlv. 

ADDR  MODE  MNEMONIC  FORMAT/OPCODE 


8 

4 

4 

R 

FMR 

RA,RB 

1 

C9 

1  RA 

1  RB  1 

4 

2 

2 

8 

B 

FMB 

BR.DSPL 

1  2 

|2 

IBR'I 

DSPL  1 

4 

2 

2 

4  4 

BX 

FMBX 

BR,RX 

1  4 

|0 

IBR'I 

A  !  RX  1 

0 

FM 

RA.AOOR 

8 

4 

4 

OX  FM  RA.ADOR.RX  |  C8  |  RA  |  RX  |  | 


12  <  BR  <  15 
BR'  =  BR  -  12 
RA  =  RO 


12  <  BR  <  15 
BR'  =  BR  -  12 
RA  =  RO 

16 


ADDR 


DHSCRIFI'ION:  The  floating  point  Derived  Operand,  IX),  is  floating  point  multiplied  by  the  contents  of  register 
RA  and  RA  + 1.  The  result  is  stored  in  register  RA  and  RA  + 1,  The  process  of  the  operation  is  as 
follows:  the  exponents  of  the  operands  arc  added.  If  the  sum  exceeds  7Fj(i,  a  floating  point 
overflow  occurs.  If  the  sum  is  less  than  SOi^,  then  underflow  occurs  and  the  result  set  to  zero.  The 
operand  mantissas  are  multiplied  and  the  result  normalized  and  stored  in  RA  and  RA  + 1.  An 
exceptional  case  is  when  both  operands  are  negative  powers  of  two:  (-1.0  x  2")  x  (-1.0  x  2"');  the 
result  isaO.5  X  2"^'"*^’.  if  n  +  m  =  7Fjfi,  this  shall  yield  an  exponent  overflow,  floating 
point  overflow  (Kcurs.  Also,  it  is  possible  that  the  normalization  process  may  yield  an  exponent 
underflow;  if  this  occurs,  tlien  the  result  is  forced  to  zero.  The  condition  status,  CS,  is  set  based  on 
the  result  in  RA  and  RA  + 1. 
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HCGISICR  IHANSI I R  DhSCRIRTlON: 
n  =  FA  +  EO: 

PI3  <--  1.  EA  <--  7Fi6.  MA  <--  7FFF  FFjg.  exit,  if  n  >  TFig  and  MAq  =  MOq; 
PI3  <--  1,  EA  <--  7Fi6.  MA  <--  8000  00, g.  exit,  if  n  >  7F,6  and  MAq  *  MOq: 


Pie 

<- 

-  1. 

EA  <- 

-  0. 

MA 

<--  0. 

exit, 

if 

n  < 

80 

16 : 

MP 

<-■ 

■  MA 

X  MO: 

( intege 

r  mul  ti| 

ply) 

MP 

<- 

-  MP 

shift 

left 

1 

position; 

n  < 

n  + 

1.  MPo 

-23  ^ 

-- 

4000  00 

le. 

'  MPo 

-23 

=  8000 

00 

16 

: 

Pl3 

<- 

-  1. 

EA  <- 

-  7F, 

ie> 

MA  <-- 

7FFF 

FFie. 

ex 

it. 

if 

n 

> 

7F,6 

and 

MPo  =  0 

PI3 

<- 

-  1. 

EA  <- 

-  7P| 

le- 

MA  <-- 

8000 

00, g. 

ex 

it. 

if 

n 

> 

7F,6 

and 

MPo  =  1 

n , 

MP 

normal 

i  zed 

n . 

MP; 

Pie 

<- 

-  1. 

EA  <- 

-  0. 

MA 

<--  0. 

exit, 

if 

n  < 

80 

16 1 

EA  <--  n; 

MA  <--  MP0.23: 

(CS)  <--  0010  if  (RA.RA+1)  »  0; 

(CS)  <--  0001  if  (RA.RA+1)  <  0; 

(CS)  <--  0100  if  (RA.RA+l)  >  0; 

REGISTERS  AFFECTED:  RA.  RA+1 .  CS.  PI 
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'  ,  ^  S  I  ■\li.-luK  li  HKClsion  Ho.ill! !1(  lift  H.lllli!ilV. 

AI>M  mode  mnemonic  ■  IJI'MAI  /CECODE 

8  -1 

K  i EMR  HA.RB  i  CB  I  MA  i  RB  | 


H  4  4  1  e 

0  t  M  KA  ,  AOUR  -  - 

i:x  ihM  RA.'OOR.KX  CA  >  HA  j  RX  ;  |  ADDR 


)!  SC'K  II’ !  ION :  !  he  cxti'iiJod  pix't  isuin  t1i  iimp  I  KtiwJ  ( ipcranti,  !  X.),  is  cxtcndi.u  llti.itinp  p.iin:  mtili  f.v 
the  ctintenis  cl  :c!>lstei^  RA  RA  -•  1.  aiKl  RA  E  2.  IBc  ivsuil  isstiued  in  p.e islets  l<A  e'  A  ‘-2  .I’l.l 
KA  r  2.  Itic  process  of  the  opi  r.itioii  is  .is  follows;  the  exponent  of  the  opcr.inds  .ii  c  idiled  II'  die 
sum  excectls  21',^,  ^  llo.uiny  point  oveillow  iitcnrs.  it  •.he  sum  is  less  tiun  so  ,  'iien  underflow 
cixLirsand  Die  result  set  to  /eri.'  fhe  opcnind  inaniissas  are  nuiliiplicd  and  the  result  noiinali/cd 
and  stored  in  KA,  KA  +  1.  and  K  \  -t-  2  I'he  condition  status,  CS,  is  set  b.ised  on  tlic  result  in  K.\, 
K.A  a  1.  and  RA  +  2. 


IH 
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REGISTFR  IRANSf  EH  DESCRlPt  ION: 
n  =  LA  £0 : 


1^13  <  1. 

EA 

<  - 

7F 

16  ■ 

MA  <-- 

7FFF 

fE  FEffis. 

exit. 

i  f  n 

7fis 

and 

MA,,  =  MOq 

PI3  L--  1. 

EA 

v.  — 

7F 

16  ■ 

MA  <-- 

8000 

00  OOOO16. 

exit. 

i  f  n  > 

7Fis 

and 

MAg  i-  MOq 

Pis  1. 

EA 

0. 

MA 

<--  0. 

exit 

.  if  n  <  80 

16 1 

MP  <--  MA  X  MO;  (integer  multiply) 


MP 

MP  shift  left  1  position: 

n  <- 

-- 

n  +  1.  MPq.jg  <--  4000  00 

0000 

16' 

if  MPg.jg  - 

8000 

00 

OOOOjg; 

PI3 

<- 

-  1.  EA  <--  7F,6,  MA  <-- 

7FFF 

FF 

FFFF16,  exit 

.  if 

n 

>  7Fj5  and 

MPfl  = 

0: 

'’I3 

<- 

-  1.  EA  <--  7F,6.  MA  <-- 

8000 

00 

OOOOtg.  exit 

.  if 

n 

>  7F,6  and 

MPo  = 

1; 

n , 

MP 

<--  normalized  n,  MP; 

Pie 

<- 

-  1.  EA  <--  0.  MA  <--  0. 

if  n 

< 

80,6; 

EA  <--  n; 

MA  <--  MP0.39: 

(CS)  <--  0010  if  (RA.  RA+l,  RA+2)  *  0; 

(CS)  <--  0001  if  (RA.  RA+l.  RA+2)  <  0; 

(CS)  <--  0100  if  (RA.  RA+l,  RA+2)  >  0; 

REGISTERS  AFFECTED:  RA.  RA+l.  RA+2,  CS.  PI 
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5.76  Single  precision  iiitcecr  divide  '^ith  16-hit  dividend. 


ADDR  MODE 

MNEMONIC 

FORMAT/OPCODE 

8 

4 

4 

R 

DVR 

RA,RB 

1  D1 

1  RA 

1  RB  1 

8 

4 

4 

ISP 

DISP 

RA.N 

1  D2 

1  RA 

lN-1  1 

1  < 

N  <  16 

8 

4 

4 

ISN 

OISN 

RA.N 

1  D3 

1  RA 

|N-1  1 

1  < 

N  <  16 

0 

OX 

DV 

DV 

RA.AODR 

RA.ADDR.RX 

8 

4 

4 

16 

I  00 

1  RA 

1  RX  1 

1 

ADDR  1 

8 

4 

4 

16 

IM 

OVIM 

RA.DATA 

1  4A 

1  RA 

1  6  1 

1 

DATA  1 

DFSCIUP  l  lON:  The  contents  of  register  RA  are  divided  by  the  Derived  Operand,  DO.  a  single  precision,  2’s 
complement  number.  The  result  is  stored  in  registers  RA  and  RA  + 1  such  that  RA  stores  the 
single  precision  integer  quotient  and  RA  + 1  stores  tlic  remainder.  The  Condition  Status.  CS,  is  set 
based  on  the  result  in  RA.  A  fixed  point  overflow  occurs  if  the  divisor,  IX),  is  zero,  or  if  the 
dividend  is  8000  and  tlie  divisor  is  FFFF15. 

Note:  The  sign  of  the  non-zero  remainder  is  the  same  as  the  sign  of  the  dividend. 

REGISTER  TRANSFER  DESCRIPTION: 

<RA.RA+1)  <--  (RA)  /  DO; 

PI4  <--  1.  if  DO  =  0  or  {RA  =  8000j6  and  DO  =  FFFFjg}; 

(CS)  <--  0010  if  (RA)  =  0; 

(CS)  <--  0001  if  (RA)  <  0; 

(CS)  <--  0100  if  (RA)  >  0; 

REGISTERS  AFFECTED:  RA,  RA+1,  CS.  PI 
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5,77  Siiiulo  precision  iincacr divide  will'  -12-bil(l>vidcml. 

ADDK  MOUF  MNEMONIC  FORMA T/OPCODE 


8 

4 

4 

R 

DR 

RA.RB 

1 

D5 

1  RA 

1  RB  1 

4 

2 

2 

8 

12  <  BR  <  16 
BR'  =  BR  -  12 
RA  =  R2 

B 

DB 

BR.DSPL 

1  1 

|3 

IBR’I 

DSPL  1 

4 

2 

2 

4  4 

12  <  BR  <  15 
BR'  =  BR  -  12 
RA  =  R2 

BX 

DBX 

BR.RX 

1  4 

|0 

IBR'I 

7  1  RX  1 

0 

DX 

RA.AOOR 

RA.ADOR.RX 

8 

4 

4 

16 

0 

1 

D4 

1  RA 

1  RX  1  1 

ADDR  1 

8 

4 

4 

16 

IM 

DIM 

RA.OATA 

1 

4A 

1  RA 

1  B  1  1 

DATA  1 

DISCRIPTION:  The  contones  of  registers  RA  and  RA  + 1,  a  double  precision  2’s  complement  number,  are  divided 
by  the  Derived  Operand,  DO,  a  single  precision,  2  s  complement  number,  RA  contains  the  MSH 
of  the  32-bit  dividend.  The  result  is  stored  in  registers  RA  and  R  A  -I- 1  such  that  RA  stores  the 
single  precision  integer  quotient  and  RA-(- 1  stores  the  remainder.  The  Condition  Status,  CS,  is 
set  based  on  the  result  in  RA.  A  fixed  point  overflow  occurs  if  the  divisor  equals  zero  or  if  the 
magnitude  of  the  MSH  of  the  dividend  is  equal  to  or  greater  than  the  magnitude  of  the  divisor 
(i.e.,  the  quotient  exceeds  15  bits). 

Note:  Ihe  sign  of  the  non-zero  remainder  is  tlic  same  as  that  of  the  dividend. 

REGISTER  TRANSFER  DESCRIPTION: 


(RA.RA+1) 

<-- 

(RA.RA+l) 

/  DO: 

PI4  <--  1 

.  if 

DO  = 

0  or 

|(RA) 

(CS) 

0010 

if 

(RA) 

=  0; 

(CS)  <-- 

0001 

if 

(RA) 

<  0; 

(CS;  <-- 

0100 

if 

(RA) 

>  0; 

REGISTERS 

AFFECTED 

RA. 

RA+1 
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MIL  STD- 1750A  (USA! ) 
2  July  1980 


5.78  I  )<Hiblc  Diccision  integer  JiMdc. 
ADOR  MODt  MNEMONIC 

R  OOR  RA.RB 


I ORMAl /OPCODE 

8  4  4 


I  D7  I  RA  I  RB  I 


8  4  4  16 

D  DO  RA.ADDR  -  - 

DX  DO  RA.AOOR.RX  |  06  |  RA  |  RX  |  |  AODR  |  | 

-  -  j 

i 

I)1:SCR1PI  ION:  The  cotucnls  of  registers  RA  and  RA-l  1,  a  double  precision  2's  complement  mimbcr.  are  divided 

by  the  Ocrived  Operand.  IXJ.  a  double  precision  2's  complement  number  RA  contains  the  MSH  | 

ol  die  .12  bit  dividend.  Ihe  quotient  part  o(  the  integer  result  is  stored  in  rcgisiers  RA  and  RA  -L  1 

(with  die  MSH  III  RA)  and  the  remaiiidei  is  lost  Ihe  Condition  Status.  CS  is  set  based  on  die 

results  III  registers  RA  and  RA  1.  A  Iked  point  overflow  occurs  if  the  divisor.  IXJ.  is  zero,  or  if 

the  dividend  is  8OOO14  and  the  divisor  is  TT'I'T'k,. 


REGISTER  TRANSEER  DESCRIPTION: 


(RA.RA-fl)  (RA.RA-i-l)  /  DO; 


PI4  <--  l,if  DO  =  0  or  {RA  =  8000,6  3bd  DO  =  FFFFjg); 


(CS)  <--  0010 
(CS)  <--  0001 
(CS)  <--  0100 


if 

(RA.RA-i-l) 

=  0; 

if 

(RA,RA+1) 

<  0; 

if 

(RA.RA+1) 

>  0; 

REGISTERS  AFFECTED:  RA,  RA+1 .  CS,  PI 


1;I7R,I)I) 
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MIL-STO-1/50A  (USAf) 
2  July  1980 


5.79  I  Iti.iLiruz  noiiii  Jivulo. 

ADDR  MOPE  MNEMONIC 


EORMAr/ORCQDE 


8 

4 

4 

R 

FDR 

RA.RB 

1 

09 

1  RA 

1  RB  1 

4 

2 

2 

8 

B 

FOB 

BR.DSPL 

1  2 

|3 

IBR’I 

DSPL  1 

4 

2 

2 

4 

4 

BX 

fOBX 

BR.RX 

1  4 

|0 

IBR’I 

B 

1  RX  1 

8 

4 

4 

OX 

FD 

RA.AOOR.RX 

1 

D8 

1  RA 

1  RX  1  1 

12  <  BR  <  15 
BR'  =  BR  -  12 
RA  =  RO 


12  <  BR  <  15 
BR’  =  BR  -  12 
RA  =  RO 


llie  floating  point  number  in  registers  RA  and  RA  + 1  is  divided  by  the  floating  point  Derived 
Operand,  IX).  Ihe  result  is  stored  in  register  RA  and  RA+ 1.  A  floating  point  overflow  occurs  if 
the  exponent  result  exceeds  7Fj^  at  any  point  in  the  calculation  process.  Underflow  occurs  if  the 
exponent  result  is  less  than  at  any  point  in  the  process.  If  underflow  occurs,  then  the 
quotient  is  forced  to  zero.  A  divide  by  zero  yields  a  floating  point  overflow. 


FDR.FDB.FDHX.FD 
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MIL-STD-1750A  (USAF) 

2  July  1980 

REGISTER  TtiANSEER  OESCRIPTION: 
n  =  EA  -  EO: 

PI3  <--  1.  EA  <--  7F,6.  MA  <--  7FFF  FFjg,  exit. 

if  MAq  =  MOq  and  {n  >  7r,6  or  DO  =  0): 

PI3  <--  1.  EA  <--  7Fi6,  MA  <--  8000  00,6.  exit. 

if  MAq  ^  MOq  and  {n  >  7f,6  or  DO  =  0} ; 

Pig  <--  1.  EA  <--  0.  MA  <--  0.  exit,  if  n  <  80,5: 

MQ  <--  MA  /  MO; 

MQ  <--  MQ  Shift  Right  Arithmetic  1  position,  n  <--  n  +  1.  if  |M0|  >  1.0; 


PI3  <--  1. 

EA 

<-- 

7Fi6. 

MA  <-- 

7FFF 

FFi6 

PI3  <--  1. 

EA 

<-- 

7Fi6. 

MA  <-- 

8000 

00,6 

EA  <--  n; 

MA  <--  MQq. 

23: 

(CS)  <--  0010  if  (RA.RA+1)  «  0 
(CS)  <--  0001  if  (RA.RA+1)  <  0 
(CS)  <--  0100  if  (RA.RA+1)  >  0 


AFFECTED:  RA.  RA+l .  CS.  PI 


IDR.I-'DIi.lDliX.KD 
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M1L-STD-1750A  (USAF) 
2  July  1900 


5.80  I  xiciijcd  pro  isioii  tlo  idiiu  ndiiit  divide 
ADDR  MOPE  MNEMONIC 


fOHHAE /OPCODE 


EEDR  RA.RB 


I  DB  I  RA  I  RB  I 


EFD  RA.AODR 
EFD  RA.ADOR.RX 


4  4 

I  RA  I  RX  I  I 


I  )I  !SCK1I*'I  ION:  ’ITic  contents  oF registers  RA.  RA  + 1,  and  RA  +  2  arc  extended  precisian  floating  point  divided  by 
die  extended  precision  floating  point  I )crivcd  Operand,  IX).  Ilic  result  is  stored  in  register  RA, 
RA  +  1,  and  RA  +  2.  A  floating  point  overflow  occurs  if  the  exponent  result  exceeds  at  any 
point  in  the  calculation  process.  Underflow  (x;curs  if  the  exponent  result  is  less  than  80j(,  at  any 
point  in  die  process.  If  underflow  occurs,  then  the  quotient  is  forced  to  zero.  A  divide  by  zero 
yields  a  floating  point  overflow. 

REGISTER  TRANSFER  DESCRIPTION: 

n  =  EA  £0; 

PI3  <--  1.  EA  <--  7Fj6.  MA  <--  7FFF  FF  FFFFje.  oxit, 
if  MAq  =  M0(j  and  {n  >  7Fjg  or  DO  =  0}; 

PI3  <--  1.  EA  <--  7F,6.  MA  <--  8000  00  0000,6. 

if  MAo  *  MOq  and  {n  >  7F,6  or  DO  »  0): 

Pig  <--  1.  EA  <--  0.  MA  <--  0.  exit,  if  n  <  80,6; 

MQ  <--  MA  /  MO; 

MQ  <--  MQ  Shift  Right  Arithmetic  1  position,  n  <--  n  +  i,  if  |MQ|  >  l.O; 


PI3  <- 

1. 

EA  <-- 

7F,6.  MA  <  — 

7FFF 

FF 

ffff,6. 

exit, 

if  n  > 

16 

and 

0 

II 

0 

PI3  <- 

1, 

EA  <-- 

7F,6.  MA  <- 

8000 

00 

0000,6, 

exit. 

if  n  > 

7Fi6 

and 

MQo  -  1: 

EA  <--  n; 

MA  <--  MOo-39: 

(CS)  <--  0010  if  (RA,  RA+1,  RA+2)  =  0; 

(CS)  <--  0001  if  (RA,  RA+1,  RA+2)  <  0; 

(CS)  <--  0100  if  (RA,  RA+1,  RA+2)  >  0; 

REGISTERS  AFFECTED:  RA,  RA+1,  RA+2.  CS.  PI 


FFDR.Fl-D 


MU  -  STD-  i  7S0A  (USAT  ) 
Jii  1  V  1900 


S.81  1ikIiim\o  lomcal  OR 


ADOR  MODE 

MNEMONIC 

lORMAT /OPCODE 

8 

4 

4 

R 

ORR 

RA.RB 

I  FI 

1  RA 

1  RB  1 

4  2 

2 

8 

12  i  BR  1  lb 
BR’  =  BR  -  12 
RA  =  R2 

B 

ORB 

BH.DSPL 

1  3  !0 

|BR'  1 

DSPL  i 

4  2 

2 

4  4 

12  i  BR  £  15 
BP’  =  BR  -  1 

RA  =  R2 

BX 

ORBX 

BR  .RX 

1  4  |0 

|BR'  1 

F  1  RX  ; 

D 

OX 

OR 

OR 

RA.ADOR 

RA.ADOR.RX 

8 

4 

4 

16 

I  f.o 

1  RA 

1  RX  1  1 

ADDR  1 

8 

4 

4 

16 

IM 

ORIM 

RA.DATA^ 

1  4A 

1  RA 

Mil 

DATA  1 

DHSCKIP'I'ION:  'ITic  Derived  Operand,  DO.  is  bit-by-bit  inclusively  ORcd  with  the  contents  of  RA.  ITie  result  is 
stored  in  register  RA.  The  condition  status,  CS,  is  set  based  on  the  result  in  register  RA. 

RTGISTER  TRANSFER  DESCRIPTION: 

(RA)  <*-  (RA)  V  DO: 

(CS)  <--  0010  if  (RA)  =  0: 

(CS)  <--  0001  if  (RA)  <  0; 

(CS)  <--  0100  if  (RA)  >  0; 

REGISTERS  AFFECTED:  RA,  CS 


OR  R.ORH.ORIlX.OR.ORIM 


MIL-STD-1760A  (USAF) 
2  July  1980 


■■Is?,  1  (iCK'.J  \NO 

ADlJli  MNLMONIC  f  OKHA I  /01‘CODE 


t 


6 

4 

4 

R 

ANDR 

RA.RB 

i 

£3 

(  RA 

(  Re  1 

4 

2 

2 

8 

12  <  BR  <  15 
BR'  =  BR  '  12 
RA  --  R2 

B 

ANDB 

BR.OSPL 

(  3 

|1 

IBR'l 

DSPl  1 

4 

2 

2 

4  4 

12  i  BR  <  1& 
BR'  *  BR  '  12 

RA  =  R2 

BX 

ANOX 

BR.KX 

i  * 

|0 

(BRi 

m 

:v 

X 

AND 

AND 

RA.AOOR 

RA,AD0R,RX 

6 

4 

4 

18 

OX 

i 

£2 

)  RA 

1  RX  1  1 

AODR  1 

8 

4 

4 

16 

IM 

ANOM 

RA.OATA 

1 

4A 

1  KA 

1  7  1  1 

DATA  1 

DF.SCklPnON:  llic  Derived  Operand,  DO,  is  b«-bybit  ANDcd  with  the  contents  of  register  KA.  (he  result  is 
stored  in  register  RA.  The  condition  status,  CS,  is  set  based  t  o  the  result  in  register  RA. 

REGISTER  TRANSFER  DESCRIPTION: 

(RA)  <--  (RA)  t  DO; 

(CS)  0010  if  (RA)  =  0; 

(CS)  0001  if  (RA)  <  0; 

(CS)  <--  0100  if  (RA)  >  0; 

REGISTERS  AFFECTED:  RA.  CS 


123  ANDK,ANDB,ANDX,AND,ANDM 
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MIL-STD-1750A  (USAF) 

2  July  1980 

5.83  t'.xcUisivc  logical  OU. 

AOOR  MODE  MNEMOWIC  FORMAT /OPCODE 


8 

4 

4 

R 

XORR 

RA.RB 

1  E5 

1  KA 

1  RB  1 

XOR 

XOR 

8 

4 

4 

16 

DX 

RA.ADOR.RX 

1  E4 

1  RA 

1  RX  1  1 

AOOR  1 

8 

4 

4 

16 

IM 

XORM 

RA.DATA 

1  4A 

1  RA 

1  9  1  1 

DATA  1 

DKSCRIFriON:  The  Derived  Operand,  DO,  is  bit-by-bit  exclusively  ORcd  with  the  contents  of  RA.  'Ihc  result  is 
stored  in  RA.  The  condition  status,  CS.  is  set  based  on  the  result  in  RA. 

REGISTER  TRANSFER  DESCRIPTION: 

(RA)  <--  (RA)  •  DO; 

(CS)  <--  0010  if  (RA)  =  0; 

(CS)  <--  0001  if  (RA)  <  0; 

(CS)  <--  0100  if  (RA)  >  0: 

registers  AFFECTED:  RA.  CS 


XORR„\OR.XORM 
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MIL-STD-1750A  (USAF) 
2  July  1980 


5.84  I  (laical  NaNI). 

AODR  MODC  MHfMQWIC 


FORMA f /OPCODE 


8 

4 

4 

R 

NR 

RA,RB 

1  £7 

1  RA  1 

1  RB  1 

n 

M 

RA.ADOR 

RA.AOOR.RX 

8 

4 

4 

16 

ox 

N 

1  E6 

1  RA  1 

1  RX  1  1 

ADDR  1 

8 

4 

4 

16 

IH 

NIM 

RA.OATA 

1  4A 

1  RA  1 

1  B  1  1 

DATA  1 

l)t-SCRIPriON:  The  Derived  Operand,  EX),  is  bil-by-bit  logically  NANDcd  with  the  contents  of  register  RA.  'Hie 
result  is  stored  in  RA. 


Note:  The  logical  NOT  of  a  register  can  be  attained  with  a  NR  instruction  with  RA  =  RB. 

register  TRANSFER  DESCRIPTION; 

(RA)  <--  7RA)  t  00; 


(CS)  <--  0010  if  (RA)  =  0 
(CS)  <--  0001  if  (RA)  <  0 
(CS)  <--  0100  if  (RA)  >  0 


REGISTERS  AFFECTED:  RA.  CS 


!  i 


MIL-STD-1750A  (USAF) 
2  July  1980 


5.85  Convert  Hoating  point  to  Ifi-hit  iiucgcr. 
ADDR  HOnE  MNEMOmC 


R  FIX  RA.RB 


FORMAT /OPCODE 

8  4  4 


I  E8  I  RA  I  RB  I 


l)l-SCRIPriON:  llic  integer  portion  of  the  floating  point  Derived  Operand,  DO  (i.e.,  the  contents  of  registers  RB 
and  RB+  1),  is  stored  into  register  RA.  If  tlie  actual  value  of  the  IX)  floating  point  exponent  is 
greater  than  OF^j.  then  RA  remains  unchanged  and  a  fixed  point  overflow  occurs,  llic  condition 
status,  CS,  is  set  based  on  die  result  in  RA. 


Note:  Ilie  algorithm  truncates  toward  zero. 

REGISTER  TRANSFER  DESCRIPTION: 

PI4  <--  I,  exit,  if  EO  >  OFig; 

(RA)  <-'  Integer  portion  of  DO; 


(CS)  <--  0010 
(CS)  <--  0001 
(CS)  <--  0100 


if 

(RA) 

=  0; 

if 

(RA) 

<  0; 

if 

(RA) 

>  0; 

REGISTERS  AFFECTED:  RA ,  CS.  PI 


FIX 


126 
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MIL-Srn-1750A  (USAF) 
2  July  1980 


5.86  Convert  l6-|->ii  intener  to  fl<vitini»  point. 
ADDK  MODE  MNEMONIC 


R  FIT  RA.RB 


FORMAT/OPCODE 

8  4  4 


I  E9  I  RA  I  RB  I 


DHSCRIP  I'ION:  IFic  integer  l^rivcd  Operand,  IX)  (i.e.,  the  contents  of  register  R  B).  is  converted  to  Single 

Precision  floating  point  format  and  stored  in  register  RA  and  RA  4- 1.  ITte  condition  status,  CS.  is 
set  based  on  the  results  in  RA  and  RA  + 1.  I  he  operation  pntcess  is  as  follows:  I  be  exponent  is 
initially  considered  to  be  OFjj.  The  integer  value  in  RB  is  nonnalized,  i.e.,  the  number  is  left 
shifted  and  the  exponent  decremented  forc.'ich  shift  until  the  sign  bit  and  the  next  MSB  arc 
unequal,  and  the  exponent  and  mantis-sa  stored  in  the  proper  fields  of  RA  and  RA  +  1. 

Note:  RA  may  equal  RB. 

An  integer  zero,  OOOOj^,  is  converted  to  a  floating  point  zero,  0000  OOOO]^. 

REGISTER  TRANSFER  DESCRIPTION: 

EA  <--  0.  MA  <--  0,  exit,  if  (RB)  =>  0; 

EA  <--  OFia: 

MA  <--  (RB): 

EA,  MA  <--  normalize  EA,  MA; 


(CS) 

<-- 

0010 

if 

(RA,RA+1) 

(CS) 

<-- 

0001 

if 

(RA,RA+1) 

(CS) 

<-- 

0100 

if 

(RA.RA+1) 

REGISTERS  AFFECTED:  RA .  RA+1 ,  CS 


127 


KI.’ 


*1  QO 


I)I-SCRII*I  ION:  The  integer  portion  of  the  floating  point  Derived  Operand,  DO  (i.c.,  tlic  contents  of  registers  RB, 
RB+ 1,  and  Rll  +  2).  is  stored  into  register  RA  ajid  RA4- 1.  If  the  actual  value  of  tlic  DO  floating 
point  exponent  is  greater  tlian  lFj(,,  then  RA  and  RA  +  1  remain  unchanged  and  a  fixed  point 
overflow  occurs.  Ihc  condition  status.  CS,  is  set  based  on  tlic  result  in  RA  and  RA  +  1. 


Note:  'Ihe  algorithm  truncates  toward  zero. 

REGISTER  TRANSFER  DESCRIPTION: 


PI4  <--  1 

,  exi 

t.  if 

EO  >  IFie: 

(RA,RA+1) 

<-- 

Integ 

er  portion 

of  00; 

(CS)  <-- 

0010 

if 

(RA,RA+1)  = 

0; 

(CS)  <-- 

0001 

if 

(RA,RA+1)  < 

0; 

(CS)  <-- 

0100 

if 

(RA.RA+1)  > 

0; 

registers 

AFFE 

■CTEO: 

RA.  RA+1, 

CS.  PI 

KFIX 
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MIL-STD-1750A  (USAf) 
2  July  1980 

3  88  Convert  37  hii  Integer  to  exieiiJevI  nrccisinii  noiiting  noint. 

ADOR  MODE  MNEMONIC  KORMA f /OPCODE 

8  4  4 

R  EFLT  RA.RB  |  EB  |  RA  |  RB  | 


1)1  SCRIP  I  ION:  l>ic  double  precision  integer  Derived  Operand,  DO  (i.c.,  the  contents  of  registers  RH  and 
RI1+  1),  iscunveited  to  Extended  I’recision  flualing  point  format  and  stored  in  register  RA, 

RA  + 1,  and  RA  +  2.  'Ihc  condition  status,  CS.  is  set  based  on  the  result  in  RA.  RA  + 1,  and 
RA  +  2.  Ihc  operation  process  is  as  follows:  Ihe  exponent  is  initially  ainsidcred  to  be  ll'jj.  The 
integer  value  in  Rl),  RB  +  1  is  normalixed,  i.c.,  the  number  is  left  shifted  and  the  exponent 
decremented  for  each  shift  until  the  sign  bit  and  the  next  MSB  arc  unequal,  and  the  exponent  and 
mantissa  stored  in  the  proper  field  of  RA,  RA  + 1,  and  RA  +  2. 

ypig:  RA  may  equal  RB. 

An  integer  rcro,  0000  OOOOj^,  is  converted  to  an  extended  floating  point  xero,  0000  0000  0000|g. 
REGISTER  TRANSFER  DESCRIPTION: 

EA  <--  0,  MA<--  0.  exit,  if  (RB,RB+1)  =  0; 


EA  <--  1Fi6.  MA<--  (RB,RB+1): 
EA,  MA  <--  normalized  EA,  MA; 


(CS)  <--  0010  if 
(CS)  <--  0001  if 
(CS)  <--  0100  if 

REGISTERS  AFFECTED: 


(RA. 

RA+1, 

(RA, 

RA+l, 

(RA, 

RA+1. 

RA. 

RA+1. 

RA+2)  *  0; 
RA+2)  <  0; 
RA+2)  >  0; 

RA+2.  C6 


129 
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Mil  SID- 1750A  (USAF) 
July  1980 


S  Sv  F  Mh.inL’o  bvt^'^  in  luristcr. 
AIJDR  MOnt  MNFMQNIC 


S  X8R  RA 


I ORMAT/OPCODL 
8  4  4 


I  tC  1  RA  I  0  i 


I  U'IN ;  llu  upper  byte  of  register  KA  is  exehjiigod  with  the  lower  byte  of  register  RA  Itie  CS  is  set 

based  (111  the  result  In  legister  RA. 

rRANSFf R  OfSCRIPTIQN: 


(  R  A  )  (,  ;  '  -  .  ;  t  R  A  )  8  - 1  ; 


(CS) 

0010 

if 

(RA)  =  0 

(fS) 

000  1 

if 

(RA)  <  0 

(CS)  <-- 

0100 

i  f 

(RA)  >  0 

Kf  CISTfRS 

;  AFFECTED 

RA,  CS 

I 


XHR 


iin 


MIL-SID-  1  750A  (USAI  ) 
2  July  1980 


s ')0  1  ushaii'ic  wi'uls  ill  iceisiers. 

ADDR  MODE  MNEMONIC 

lORMA I /OPCODE 

6 

4  4 

R  XWR  RA.RB 

1  EO 

1  RA  1  RB 

i)l  SCRIP!  ION:  llic  contents  of  register  RA  arc  exchanged  witJi  the  contents  of  register  Rli.  11)0  CS  is  set  based 
on  the  result  m  register  RA 

REGISTER  TRANSFER  DESCRIPTION: 

(RA)  <-->  (RB); 

(CS)  <--  0010  if  (RA)  =  0; 

(CS)  <--  0001  if  (RA)  <  0; 

(CS)  <--  0100  if  (RA)  >  0; 

REGISTERS  AEEECTED:  RA ,  RB.  CS 


131  XWR 

if)  t 


MIL-STD-1750A  (USAF) 
2  July  1980 


5.91  Single  precision  comnarc. 
ADDR  MODE  MNEMONIC 


FORMAT/OPCODE 
8  4  4 


R 

CR 

RA,R8 

1  FI 

1  RA  1  RB  1 

4  2 

2  8 

12  <  BR  <  15 
BR'  =  BR  -  12 
RA  =  R2 

B 

CB 

BR.DSPL 

1  3  |2 

IBR'l  DSPL  1 

4  2 

2  4  4 

12  <  BR  <  15 

1  BR'  =  BR  -  12 

BX 

CBX 

BR.RX 

1  4  |0 

|BR' 1  C  1  RX  1 

8 

4  4 

ISP 

CISP 

RA,N 

1  F2 

1  RA  |N-1  1 

1  <  N  <  16 

8 

4  4 

ISN 

CISN 

RA,N 

1  F3 

1  RA  |N-1  1 

1  <  N  <  16 

C 

C 

RA,ADDR 

RA.ADDR,RX 

8 

4  4 

16 

DX 

1  FO 

1  RA  1  RX  1  1 

ADDR  1 

8 

4  4 

16 

IM 

CIM 

RA,DATA 

1  4A 

1  RA  1  A  11 

DATA  1 

DFSCRIPTION; 

The  single  precision  Derived  Operand.  IX),  is  compared  lo  the  contents  of  RA.  Then,  the 
Condition  Status,  CS,  is  set  based  on  whether  the  contents  oTRA  is  less  than,  equal  to,  or  greater 
than  the  DO.  The  contents  of  RA  arc  unchanged. 

REGISTER  TRANSFER  DESCRIPTION: 


(RA)  :  DO; 

(CS)  <--  0010  if  (RA)  =  DO; 

(CS)  <--  0001  if  (RA)  <  DO; 

(CS)  <--  0100  if  (RA)  >  DO; 

REGISTERS  AFFECTED:  CS 


CR.CM.C  UX.CISP.CISN.C.CIM 
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S  ').’’  Coiiipaic  bci'vrcn  limits. 

/UlDli  tiQPl  MNLMOMIC  lOKMA I /OPCODE 


8  4  4  16 

D  CBL  RA.ADDR  - - - - - - - 

DX  CBL  RA.AOOR.RX  |  14  |  RA  |  RX  |  |  ADDR  | 


OI.SCRIPTION:  IIjc  contcnls  of  register  RA  arc  compared  to  two  different  sixteen  bit  derived  operands,  IX)1  and 
1X)2.  The  derived  operands,  IX)1  and  IX)2  arc  located  at  DA  and  IM  +  1.  respectively,  and  their 
values  arc  defined  such  that  1X>1  <  IX)2.  Iltc  CS  is  set  based  on  the  results.  If  the  values  for  IX)! 
and  1XD2  arc  defined  incorrectly  (that  is,  IX)1  >  1X32),  tlien  CS  is  set  to  1000 


REGISTER  TRAWSFER  DESCRIPTION; 

(CS)  <--  1000  if  DOl  >  D02,  «xit; 
(CS)  <--  0001  if  (RA)  <  001; 

(CS)  <--  0010  if  DOl  <  (RA)  1  002; 
(CS)  <--  0100  if  (RA)  >  002; 
REGISTERS  AFFECTED:  CS 


133 
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5.93  I  louhic  precision  conipnre. 
ADDR  MODE  MNEMONIC 

R  OCR  RA.RB 


0 

OX 


DC 

DC 


RA.AOOR 

RA.ADOR.RX 


FORMAT /OPCODE 
8  4  4 

1  F7  I  HA  I  RB  I 

8  4  4  16 

I  F6  I  RA  I  RX  I  I  AOOR 


Df-SCR  IP  ITON:  ITic  double  precision  Derived  Operand.  IX),  is  compared  to  the  contents  of  registers  KA  and 

RA  +  1  where  RA  cont.iins  the  MSI  I  of  .i  double  precision  word.  'ITtcn.  the  Condition  Status.  CS, 
is  set  based  on  whether  die  contents  of  K  A,  R  A  +  I  is  less  than,  equal  to,  or  greater  than  the  DO. 
lYie  contents  of  RA  and  RA  +  l  arc  unchanged. 

REGISTER  TRANSFER  DESCRIPTION: 


(RA.RA+1)  :  DO; 


(CS) 

<-- 

0010 

if 

(RA.RAtI) 

=  Do 

(CS) 

<-- 

0001 

if 

(RA,RA+1) 

<  DO 

(CS) 

<-- 

0100 

if 

(RA.RA+l) 

>  DC 

REGISTERS  AFFECTED:  CS 


DCR.DC 
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5.94  [  Ix.ihni!  iioim  comnarc. 

ADDH  MODE  MNEMONIC  I  OHM AT /OPCODE 


8  4  4 


R 

FCR 

RA.RB 

1 

F9 

1  RA 

1  RB  1 

4 

2 

2 

8 

B 

FCB 

BR,OSPL 

1  3 

|3 

IBR'i 

DSPL  1 

4 

2 

2 

4 

4 

BX 

FCBX 

BR.RX 

1  4 

|0 

IBR'I 

D 

1  RX  1 

0 

FC 

EC 

RA.AODR 

RA.ADDR.RX 

8 

4 

4 

DX 

1 

F8 

1  RA 

1  RX  1  1 

12  <  BR  <  16 
BR’  =  BR  -  12 
RA  ‘  RO 


12  i  BR  <  15 
BR'  =  BR  -  12 
RA  -  RO 

16 


ADDR  I 


DFSCRIFI  ION:  The  floating  point  number  in  registers  RA  and  RA  + 1  is  compared  to  the  floating  point  Derived 
Operand,  DO.  Then,  the  Condition  Status,  CS,  is  set  based  on  whether  the  eontents  of  RA, 

R  A  + 1  is  less  than,  equal  to,  or  greater  than  the  DO.  'fhe  contents  of  RA  and  RA  + 1  arc 
unchanged. 


Note:  This  instruction  docs  not  cause  an  overflow  to  occur. 

RfGISILB  transfer  DESCRIPTION; 


(RA.RA+1)  :  DO; 


(CS)  <-- 

0010 

if 

(RA,RA+1) 

=  0; 

(CS)  S-- 

0001 

if 

(RA,RA+1) 

<  0; 

(CS)  <-- 

0100 

if 

(RA.RA+l) 

>  C; 

REGISTERS  AFFECTED:  CS 
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5.95  l-AtcnJcd  precision  floating  point  compare. 
ACOR  MODE  MWEMONIC 

R  EFCR  RA.RB 


D 

OX 


EFC 

EFC 


RA.ADOR 

RA.AOOR.RX 


FORMAT/OPCODE 
8  4  4 

I  FB  I  RA  I  RB  I 

8  4  4  16 

I  FA  I  RA  I  RX  I  I  ADDR  | 


DhSCKIP  l'ION:  The  extended  precision  floating  Derived  Operand,  IX),  is  compared  to  the  contents  of  registers 
RA,  RA+ 1,  and  RA  +  2  where  RA  contains  the  most  significant  16-bits  of  the  extended  precision 
floating  point  word.  'Ihe  condition  status,  CS,  is  set  based  on  whether  the  contents  of  RA,  RA  -i- 1, 
and  RA  -L  2  are  less  than,  equal  to  or  greater  than  the  IX).  Ihe  contents  of  RA.  RA  -l- 1,  and 
RA  -I-  2  are  unchanged. 

Note:  This  instruction  docs  not  cause  overflow  to  occur. 

REGISTER  TRANSFER  DESCRIPTION: 

(RA.  RA+1,  RA-f2)  :  DO; 

(CS)  <--  0010  if  (RA,  RA-i-1.  RA+2)  =  DO; 

(CS)  <--  0001  if  (RA,  RA-i-l.  RA+2)  <  DO; 

(CS)  <--  0100  if  (RA.  RA+l,  RA+2)  >  DO; 

REGISTERS  AFFECTED:  CS 


r.l-CR,F,FC 
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S.Oti  Nt)  onoMlioii. 

ADDR  MODE  MNEMOWIC  fORMAr /OPCODE 

8  4  4 


S  NOP  I  FF  I  0  I  0  I 
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>  9  ^  Hicak  point. 

ADOR  MODE  MNEMONIC 


S  BPT 


I ORMAl /OPCODE 
3  4  4 


I  FF  I  F  I  F  I 


DI-'SCRIP  I  'ON:  lliis  mstnictiun  is  typically  used  lei  i'alting  the  processor  duiing  ni  iimcnancc  ;md  diagnostic 
procedures  when  the  maintenance  console  is  connected  to  the  system.  If  the  console  .s  not 
connected,  this  instniction  is  treated  as  a  sOP  t  sce  page  1.17).  Kcstarting  the  processor  after  a 
DP  I  can  only  he  June  hy.  the  maintenance  console  or  the  power  on  sequence. 

REGISTER  TRANSFER  DESCRIPTION:  None 

REGISTERS  AFFECTED:  Nona 


IJFl 
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DSCR  54 

OSLC  48 

DSLL  45 

DSLR  52 

DSR  104 

OSRA  47 

OSRL  46 

OST  81 

OSTB  81 

nSII  81 

OSTX  81 

DSUR  30 

DV  116 

DVIH  116 

OVR  116 

EfA  97 

[FAR  97 

EfC  136 

EFCR  136 

[FO  121 
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EFIX  128 

Ef  L  74 

EFI.T  129 

EFM  114 

EFMR  114 

EFS  107 

FFSR  107 

[FSI  84 

ENBl  29 

ESUR  30 
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L 

70 

LB 

70 

LBX 

70 

LI 

70 

L  IM 

70 

1  ISN 

/O 

LISP 

70 

1  1  B 

76 

LI  BI 

76 

LH 

73 

1  HP 

31 

lR 

70 

LSI 

67 

.sri 

67 

lue 

75 

LUil 

76 

M 

no 

MB 

no 

M6X 

no 

HIM 

no 

MISK 

109 

MI  SP 

109 

MOV 

60 

MPf  H 

30 

MR 

1  10 

MS 

109 

MSIH 

109 

MSP 

109 

1  rs 

'.iU 
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- 
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!  NR 

\ 
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00 

30 

[  I  OR 

122 

1 

J  ORB 
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1 

t  ORBX 

122 

ORIM 

122 

ORR 

122 

OTA 

30 

OTB 

31 

PI 

>9 

j 

PO 

29 

j 
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77 

PSHM 

87 

i 

R8 

38 

i 
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36 
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31 

.5 
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31 
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31 
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1  RIC2 

31 
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32 
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MIL-STD-1760  (Draft)  STANDARD  STORES  INTERFACE, 
AIRCRAFT/STORES  ELECTRICAL  INTERFACE  DEFINITION 


1.  This  Military  Standard  has  been  approved  for  use  by  all  Departments 
and  Agencies  of  the  Department  of  Defense. 

2,  Recotnme.aded  corrections,  additions,  or  deletions  should  be  addressee 
to  U.S.  Air  Force  Armament  Laboratory,  Attention:  AFATL/DUA,  Eglln  Air 
Force  Base,  Florida  32342 


POBEWORD 


/ 

1.  Prior  to  this  standard,  an  aircraft  and  the  stores  which  It  carried 
were  typically  developed  Independently  of  each  other  or  were  developed 
exclusively  for  each  ocher.  The  usual  results  were  new  aircraft /store 
electrical  Interface  requirements  and  the  general  proliferation  of  overall 
store  Interface  requirements.  The  lack  of  standards  within  DoD  for  an 
aircraft /store  electrical  interface  led  to  low  levels  of  Interoperability 
and  costly  aircraft  modifications  to  achieve  required  store  utilization 
flexibility.  The  trend  in  store  technology  toward  more  complex  store 
functions  which  require  Increasing  amounts  of  avionics  data  from  aircraft 
systems  was  predicted  to  produce  Insurmountable  aircraft /store  Interface 
problems . 

2.  This  standard  contains  a  solution  to  aircraft /store  Interface  Imple¬ 
mentation  proliferation  by  specifying  one  standard  electrical  interface 
ioT  all  future  aircraft  and  stores.  The  Interface  contained  herein  is 
based  on  recognized  trends  in  stores  management  systems  which  predict 
Che  use  of  serial  digital  transmission  for  control,  monitor,  and  release 
signals  to  the  store  station.  Application  of  this  standard  to  new  air¬ 
craft  and  stores  will  serve  to  reduce  and  stabilize  the  number  end  variety 
of  signals  required  at  the  aircraft /store  Interface,  minimize  the  Impact 

of  new  stores  on  future  stores  management  systems,  and  Increase  store  inter¬ 
operability  within  the  services  and  MATO. 

3.  After  Initial  implementation  of  the  standard,  there  will  be  a  period 
when  both  standard  and  non-standard  aircraft  and  stores  will  coexist  in 
the  Inventory.  Therefore,  in  order  to  be  compatible,  some  development 
aircraft  and  stores  may  be  built  with  both  the  standard  and  non-standard 
interfaces . 

4.  The  format  of  this  standard  is  aligned  to  aircraft/store  Interfax* 
control  documents  used  by  industry  to  describe  aircraft/slore  int,i'4 
requirements  to  DoD. 

5.  Unless  otherwise  specified,  this  standard  ronf 
System  2,  Digital  Interface  Requirements  doi  i»« 
development  with  the  Department  f  Vr,'. 
and  appropriate  DoD  agencies. 
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1 .  INTRODUCTION 


1.1  Scope.  This  standard  establishes  the  definition  for  develojnaent , 
application,  and  control  of  the  electrical  interface  between  stores  and 
their  carrying  aircraft.  It  encompasses  all  aircraft-to-store  and  store- 
to-aircraft  signal  functions,  electrical  characteristics,  and  electrical 
connector  components  of  the  interface.  It  implies,  but  does  not  quantify, 
aircraft/store  electrical  systems  to  meet  the  Interface  defined  herein. 

It  is  intended  that  all  aircraft  stores  which  require  any  electrical  inter¬ 
face  shall  use  the  same  functional  interface  and  the  same  physical  connectors. 
This  document  does  not  include  the  design  of  the  physical  connectors,  but 
has  design  guides  for  them.  Stores  which  require  a  limited  subset  of  the 
functions  will  contain  the  necessary  electronics  to  accept  those  portions 
of  the  functional  interface  signals  required  without  aircraft  hardware 
modifications.  This  standard  does  not  imply  that  all  aircraft  can  carry 
ail  stores  on  all  stations.  Factors  such  as  physical  and  me.:h''nlcal  limi¬ 
tations,  and  electrical  power  must  be  considered. 

1.2  Purpose.  The  purpose  of  this  Interface  standard  is  threefold:  (1) 

Define  specific  electrical  and  optical  characteristics  of  power  and  data 
signals  to  be  provided  at  the  interface,  (2)  Provide  guidelines  for  inter¬ 
face  connectors,  (3)  Define  the  logical  portion  of  the  interface  which 
Includes  the  Interface  message  traffic  and  information  coding  formats  (TBD) . 

1.3  Classification.  This  standard  covers  all  aircraft  stores  that  require 
an  electrical  Interface.  This  coverage  encompasses  both  expendable  and 
non-expendable  stores  as  defined  in  NATO  AAP-6.  Non-expendable  stores  in¬ 
clude  suspension  equipment  as  defined  in  NATO  AAP-6. 

1.4  Effeccivity  Data.  Upon  date  of  implementation,  this  standard  is 
effective  with  stores  and  aircraft  in  concept  development  stages  and  all 
future  aircraft  and  all  store  development  within  the  classification  data 
provided  above. 

2 .  REFERENCED  DOCUMENTS 

2.1  Issues  of  Documents.  The  following  documents  of  the  issue  in  effect 
on  date  of  invitation  for  bid  or  request  for  proposal  form  a  part  of  this 
standard  to  the  extent  specified  herein.  In  the  event  of  conflict  between 
the  documents  referenced  herein  and  the  contents  of  this  standard,  the 
contents  of  this  standard  shall  be  considered  a  superseding  requirement. 


SPECIFICATIONS 

MILITARY:  MIL-E-6051 

Electromagnetic  Comp  Reqmts 

System 

MIL-W-5088 

Wiring,  Aerospace  Vehicle 

MIL-A-8591 

-  Airborne  Stores,  Associated  Suspension 
Lugs,  and  Aircraft  Store  Interface 
(Carriage  Phase) 
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MIL-C- 38999 


Connectors,  Electrical* 


MIL-C-27599  -  Connector,  Electrical,  Mlnature, 

Quick  Disconnect  (For  Weapons  Systems) 
Established  Reliability • 

STANDARDS 

MILITARY:  MIL-STD-461  -  Electromagnetic  Interference  Character¬ 

istics  ,  Requirements  for  Equipment . 

MIL-STD-462  -  Electromagnetic  Interference  Character¬ 

istics,  Measurement  of* 

MIL-STD-704  -  Aircraft  Electric  Power  Characteristics. 

MIL-STD-1553  -  Aircraft  Internal  Time  Division  Command/ 

Response  Multiplex  Data  Bus . 

HANDBOOKS 

MILITARY:  AFSC  DH  1-4  -  Electromagnetic  Compatibility. 

2.2  Other  Publications.  The  following  documents  form  a  part  of  this  stan¬ 
dard  to  the  extent  specified  herein.  Unless  otherwise  Indicated,  the  Issue 
In  effect  on  date  of  Invitation  for  bid  or  request  for  proposal  shall  apply. 
In  the  event  of  conflict  between  the  documents  referenced  herein  and  the 
contents  of  this  standard,  the  contents  of  this  standard  shall  be  considered 
a  superseding  requirement. 

EIA  STD  RS-330  -  Electrical  Performance  Standards  for 

Closed  Circuit  Television  Camera  525/60 
Interlaced  2:1. 

STANAG  3558  -  NATO  Standardization  Agreement.  Location 

of  the  Electrical  Control  Connector  for 
Airborne  Armament  Stores. 

STANAG  3838AA  -  NATO  Standardization  Agreement.  Aircraft 

(DRAFT)  Internal  Time  Division  Command /Response 

Multiplex  Data  Bus. 

EIA  STD  RS-343A  -  Electrical  Performance  Standard  for  High 

Resolution  Monochrome  Closed  Circuit 
Television  Camera. 

SYSTEM  2  -  Nuclear  Digital  Interface  Requirements. 

MATO  AAP-6  -  NATO  Glossary  of  Terms  and  Definitions 

for  Military  Use. 
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3.  DEFINITIONS 


3.1  Address.  A  store  location  Identification,  as  represented  by  a  five- 
digit  binary  number. 

3.2  Aircraft .  For  the  purpose  of  the  standard,  the  term  aircraft  shall 
be  that  which  serves  the  function  of  commanding,  scanning,  and  monitoring 
bus  traffic,  and  which  provides  electrical  power. 

3.3  Eu~  ^L-.terface  Electronics.  The  electronic  module  necessary  to  inter¬ 
face  the  data  bus  with  the  subsystem  and  the  subsystem  with  the  data  bus. 

3.4  EIA.  Electronic  Industries  Association. 

3.5  EMI.  Electromagnetic  Interference. 

3.6  EMC.  Electromagnetic  Compatibility. 

3.7  EM?.  Electromagnetic  Pulse. 

3.8  GPS.  Global  Positioning  System. 

3.9  Message .  A  message  is  a  time  sequential  transmission  of  words  on 
the  data  bus.  A  message  transfer  is  complete  when  the  command  word,  data 
word(s)  and  the  status  word(s)  have  been  transmitted.  There  are  three 
types  of  messages:  (1)  Aircraft-to-store,  (2)  Store-to-aircraft,  and  (3) 
Store-to-store. 

3.10  Electrical  Interface.  The  connectors  through  which  the  data  signals 
and  power  flow  between  the  aircraft  and  store. 

3.11  Bit .  Contraction  of  binary  digit;  may  be  either  0  (zero)  or  1  (one). 

It  is  equal  to  one  binary  decision  or  the  designation  of  one  of  two  possible 
values  or  states  of  anything  used  to  store  or  convey  information. 

3.12  Bit  Rate.  The  number  of  bits  transmitted  per  second. 

3.13  Half  Duplex.  Data  transfer  in  either  direction  over  a  single  line 
but  not  in  both  directions  on  that  line  simultaneously. 

3.14  Command /Response  Mode.  Operation  of  data  link  in  which  the  store 
will  respond  only  when  commanded  by  the  aircraft . 

3.15  Asynchronous  -  Operation.  An  independent  clock  source  in  each  store 
which  is  utilized  for  the  transmission  of  messages.  The  received  messages 
shall  be  decoded  using  clock  information  derived  from  the  received  signal. 

3.16  Aircraft/Store  Interface.  The  electrical  (connector)  interface 
between  the  aircraft  electrical  system  and  the  store  electrical  umbilical 
cable. 
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3.17 


Byte.  Each  half  oT  a  If-bit  word  (Sblts)  Is  a  byte. 


3.18  Store.  Same  as  aircraft  store  In  HATO  AAP-6,  repeated  here  for 
convenience.  Any  device  intended  for  internal  or  external  carriage  and 
mounting  on  aircraft  suspension  and  release  equipment,  whether  or  not 
the  item  is  Intended  to  be  separated  in  flight  from  the  aircraft.  Air¬ 
craft  stores  are  classified  in  two  categories  as  follows; 

a.  Expendable  store  -  an  aircraft  store  normally  separated  from 
the  aircraft  in  flight  such  as  a  missile,  rocket,  bomb,  nuclear  weapon, 
torpedo,  pyrotechnic  device,  sonobuoy,  signal,  underwater  sound  device, 
and  other  similar  items. 

b.  Non-expendable  store  -  an  aircraft  store  which  is  not  normally 
separated  from  the  aircraft  in  flight  such  as  a  tank  (fuel  and  spray) , 
line-source  disseminator,  pods  (refueling,  thrust  augmentation,  gun, 
electronic-countermeasure,  data  link,  etc.),  target,  cargo  drop  container, 
drone  and  other  similar  items. 

NOTE:  For  the  purposes  of  this  standard,  non-expendable  stores 
include  suspension  equipment  (racks,  adapters,  missile  launchers,  etc). 

It  excludes  thrust  augmentation  devices. 

3.19  TCP .  Time  Correlation  Pulse. 

3.20  TBD.  To  Be  Determined. 

4.  GENERAL  STATEMENTS  OF  REQUIREMENTS 

4.1  Introduction.  This  standard  defines  an  alrcraft-to-store  electrical 
interface  in  terms  of  its  physical,  electrical,  and  logical  elements.  The 
aircraft /store  interfacing  is  accomplished  through  a  maximum  of  two  elec¬ 
trical  connectors  per  store  and  is  defined  at  the  store  receptacle  discon¬ 
nect  and  at  the  aircraft  skin  (see  Figure  1).  This  standard  addresses 
only  the  aircraft-to-store  interface,  however,  it  is  intended  that  this 
standard  interfacing  concept  will  also  be  applied  to  electrical  interfaces 
between  stores  (e.g.,  launcher-to-missile)  and  will  be  addressed  in  further 
versions  of  the  MIL-STD.  In  this  standard,  the  interface  is  categorized 
and  defined  in  three  generic  parts:  (1)  Electrical  (voltage,  current, 
resistance,  isolation,  risetime,  etc),  (2)  Physical  (connector  characteristics, 
pin  size,  mounting,  etc),  and  (3)  Logical  (information  content,  protocols, 
timing,  etc)  -  TBD. 

4.2  Standard  Interface  System.  The  standard  interface  system  consists  of 
a  composite  set  of  electrical /optical  circuits,  and  specific  interface  con¬ 
nectors.  The  signal  set  is  comprised  of  redundant  digital  multiplex  data 
buses,  coaxial  contacts  for  high  bandwidth  signals,  aircraft  AC  and  DC 
power,  dlglt£d.  address  lines,  and  a  limited  number  of  dedicated  hardwired 
discretes.  Provisions  are  included  for  digital  multiplex  data  transfer 
over  twisted  shielded  pairs  and  optionally  through  fiber  optic  cable. 
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Interface  aignals  (electrical)  are  specified  in  5.2.  Interface  connector 
(physical)  requirements  and  environmental  conditions  are  speclflec  In  5.3 
and  Appendix  A.  Information  Interface  (logical)  will  be  speclflec  In  5 . 
(TBD) 

^•2.1  Digital  Multiplex  Data  Buses.  The  majority  of  all  command,  control 
and  status  data  transfer  between  the  store  and  the  aircraft  is  performed 
through  redundant  digital  multiplex  data  buses  as  specified  In  5.2.1  and 
described  by  MII.-STD-1553.  Store  connection  to  the  aircraft  data  bus  Is 
accomplished  using  stubbing  methods  also  prescribed  in  MlL-STD-1553 .  Data 
buses  are  operated  by  the  aircraft  In  an  active  standby  redundant  mode. 

The  aircraft  connands  the  store  to  perform  functions  and  transmit  store 
status  using  specially  formatted  digital  messages.  The  interface  defined 
herein  is  Intended  to  provide  sufficient  capacity  and  performance  to  satisfy 
the  requirements  of  all  future  store  types, 

4.2.2  Aircraft  Power .  The  aircraft  supplies  DC  and  AC  power  to  the  store 
interface  in  accordance  with  MIL-STD-704 .  Interface  power  requirements  and 
exceptions  to  MIL-STD-704  are  specified  in  5.2.5. 

4.2.3  High  Bandwidth  Signals.  Coaxial  and  fiber  optic  contacts  are  pro¬ 
vided  in  the  standard  Interface  connector  to  accommodate  high  bandwidth 
(RF,  Video,  Audio)  interface  signals.  User  guidelines  for  these  interface 
circuits  are  specified  in  5.2.3. 

4.2.4  Store  Address  Lines.  Dedicated  hardwire  circuits  that  provide  a 
unique  store  address  .  Detail  characteristics  of  these  circuits  are  speci¬ 
fied  in  5.2.4. 

4.3  Store  Inplications.  The  interface  prescribed  by  this  standard  requires 
that  each  store  contain  electronic  circuitry  necessary  to  interface  the 
store  directly  onto  the  aircraft’s  digital  data  bus.  This  store  electronics 
must  be  capable  of  receiving  and  transmitting  digital  multiplex  data  as 
defined  in  MIL-STD-1553  and  be  capable  of  converting  digital  data  Int 
required  store  commands.  A  functional  diagram  of  representative  «(■  ' 
circuitry  is  contained  in  Figure  2. 

4.4  Stores  Management  System  Architecture.  The  »\\  ■  »•  >  .apabie 

of  transmitting  and  receiving  digital  multiple'  '  controller 

as  defined  in  MIL-STD-1553.  This  atandat  prescribe,  or 

recommend  a  particular  stores  manaKf't  .itrcture.  The  standard 

is  designed  to  be  applicable  t  >  »  .  .neH  management  schemes. 

Viable  schemes  found  to  be  •  this  standard  should  be  re¬ 
ported  to  th'-  U.f  A)'  .  Laboratory,  Eglln  Air  Force  Base, 

Florida. 

5  DR*  .  -  o  requirements 


-uu>  t Ion.  This  section  prescribes  detail  electrical  and  physical 
em«nia  for  the  standard  aircraft/store  Interface.  Signal  functions, 
•  rlcal  characteristics  and  connector  pin  assignments  are  specified,  as 


ar*  apufK  lft  •  «uo  opeiatlng  requirements  for  the  standard  Inter- 

t  a>  r  r  ■  • 


'  a^trlcal  Interface  Definition.  All  aircraft  electrical  Interface 
. •  .  . ; r i  mcnt a  with  allotted  stores  shall  be  accomplished  through  the  elec¬ 
trical  signal  seta  contained  in  Figures  3a  and  3b,  and  defined  In  Table  1. 
The  particular  pin  asslgrunent  and  arrangement  for  the  SSI  and  Auxiliary 
Power  connectors  are  provided  for  identification  and  traceability  purposes 
only.  Definitive  signal  and  connector  characteristics  will  be  provided  in 
further  versions  of  this  MIL-STD.  Also,  spare  pins,  which  are  required 
for  future  growth,  are  not  shown  and  will  be  addressed  later.  Signals 
supplied  by  these  two  connectors  are  arranged  in  descending  order,  starting 
with  high  bandwidth  signals  and  ending  with  structural  ground.  Five  signal 
types  are  contained  in  the  interface:  (1)  High  bandwidth  signals,  (2) 

Serial  digital  data  buses,  (3)  Store  address  lines,  (4)  Dedicated  discrete 
lines,  and  (5)  High  and  low  aircraft  power.  Eac’i  interface  line  is  defined 
in  Table  1  with  one  line  per  page.  The  pages  are  arranged  alphabetically 
by  pin  letter(s)  for  the  SSI  connector,  and  by  pin  number(s)  for  the  Aux¬ 
iliary  Power  connector  for  quick  reference.  Each  signal  description  follows 
the  standard  format  defined  below: 


PIN: 


TITLE; 


Each  Interface  connector  pin  in  the  SSI  connector 
(Figure  3a)  is  assigned  an  alphabetic  nomenclature 
beginning  with  upper  case  and  continuing  through 
the  lower  case  letters.  The  letters  I,  0,  i,  and 
1  arc  not  used  to  avoid  possible  confusion.  In 
the  Auxiliary  Power  connector  (Figure  3b)  each  pin 
is  assigned  a  number. 

Specifies  signal  name. 


FUNCTION : 


Describes  the  function  performed  by  the  signal  in 
the  store  or  carrier  aircraft. 


SOURCE: 


Indicates  the  source  of  the  signal  (signal  trans¬ 
mitter)  . 


DESTINATION : 


Indicates  the  destination  of  the  signal  (signal 
receiver) . 


RETURN:  Cross-references  the  return  path  for  the  signal 

being  described. 

CONTACT:  Describes  the  contact  size.  It  also  describes 

special  wire  treatment  such  as  twisted  pair  or 
shielding. 


CKAKACTERISTICS :  Indicates  type  of  signal  and  specifics  signal 

characteristics  such  as  range,  scale  factor  and 
polarity  or  phasing.  Except  as  noted,  aircraft 
power  signals  are  specified  to  meet  MIL-STD-704 
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UMBILICAL 


HlRh  Bandwidth  Signals 

- High  Bandwidth  Line  1 — 

- High  Bandwidth  Line  2 — 

- High  Bandwidth  Line  3 — 

- High  Bandwidth  Line  4  — 

- Store  Audio - 

Serial  Digital  Data  Buses 

- Data  Bus  A  (+)■ - 

- Data  Bub  A  — 

- Bus  A  Shield - 

- Data  Bub  B  (+) - 

- Data  Bub  B  (-) - 

- Bus  B  Shield - 

— Fiber  Optic  Data  Bus  A — 
- Fiber  Optic  Data  Bus  B — 

Store  Address  Lines 


— Address  Line  1 - 

— Address  Line  2 - 

— Address  Line  3 - 

—  Address  Line  4 - 

—  Address  Line  5 - 

- Parity - 

Address  Line  Return 

Dedicated  Discretes 


-Emergency  Jettlaon- 


•Store  Present  Interlock- 


Aircraft  Power 


- 115  VAC  400  Hz  Phase  A - 

- 115  VAC  400  Hz  Phase  B - 

- 115  VAC  400  Hz  Phase  C - 

- 115  VAC  400  Hz  Return - 

■Initial  Store  Power  (28  VDC) 

- 28  VDC  Power  1 - 

- 28  VDC  Power  2 - 

- Power  1  Return - 

- Power  2  Return - 

-  Structure  Ground - 


Figure  3a  -  Electrical  Signal- Set  SSI  Connector 


UMBILICAL 


To 

Aircraft 

Connector 


Aircraft  Power 


To 

Store 

Connector 


■115  VAC  400  Hz  Phase  A- 


-115  VAC  400  Hz  Phase  A- 


-115  VAC  400  Hz  Phase  B- 


-115  VAC  400  Hz  Phase  B- 


-115  VAC  400  Hz  Phase  C- 


•115  VAC  400  Hz  Phase  C- 


■115  VAC  400  Hz  Return 


-115  VAC  400  Hz  Return  - 


— 28  VDC  Power  3- 
— 28  VDC  Power  3‘ 


■28  VDC  Power  3  Retum- 


-28  VDC  Power  3  Return- 


Figure  3b  -  Electrical  Signal  Set-Auxiliary  Power  Connector 
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standards.  Discrete  signals  are  always  binary 
and  both  voltage  and  logic  states  are  described. 

LOAD:  Specifies  the  electrical  current  load  requlreiaent . 

Load  or  source  impedances  in  the  weapon  when  specified 
are  resistive  unless  otherwise  stated. 

REMARKS:  Provides  additio  .  comments,  safety  isolation  re¬ 

quirements,  references  and/or  other  pertinent  infor¬ 
mation  . 

5.2.1  PiRital  Multiplex  Data  Bus.  The  functions  of  pins  F,  G,  H  and  J,  K, 

L  are  to  provide  stub  connections  to  two  dual  redundant  bidirectional  serial 
digital  multiplex  buses  which  shall  be  used  to  trans^'er  data  between  the 
aircraft  and  the  store.  The  store  shall  contain  bus  interface  electronics 
configured  to  interface  two  independent  data  buses  to  one  set  of  store  sub- 
systec  signals.  Serial  data  words  ana  synchronization  are  combined  by  means 
of  Manchester  biphase  coding  into  one  signal  transmitted  over  a  shielded, 
twisted  pair  of  conductors.  The  following  paragraphs  specify  bus  interface 
rcCjUlrements  that  s.nall  be  satisfied  by  both  the  aircraft  and  the  store. 
Requirements  pertain  to  both  digital  buses. 

5. 2. 1.1  Data  Bus  Operation.  The  information  flow  on  the  data  buses  shall 
be  comprised  of  messages  that  are  formed  by  three  types  of  words  (command, 
data,  status)  as  defined  in  para  4.3  of  MIL-STD-1553 .  The  aircraft/store 
multiplex  data  buses  in  their  most  elemental  configuration  are  shown  in 
Figure  4a,  more  complex  conf igurations ,  as  illustrated  in  Figures  4d  and 
4c,  will  be  defined  in  fi  rther  versions  of  this  standard.  The  data  buses 
shall  function  asynchronously  in  a  command /response  mode  with  transmission 
occurring  in  a  half-duplex  manner.  Sole  control  of  message  transmission 
on  the  buses  shall  reside  with  the  aircraft.  Data  format,  content,  pro¬ 
tocol,  and  timing  for  these  messages  will  be  completely  specified  in  further 
versions  of  this  Interface  standard. 

5. 2. 1.1.1  Subaddress /Mode .  The  subaddress /mode  field  in  the  command  word 
illustrated  in  Figure  3  and  paragraph  4. 3. 3. 5.1  of  MlL-STD-1553  is  hereby 
defined  for  application  to  aircraft /store  interfaces. 

5.2.  1.1. 1.1  Mode  Control.  The  five  bits  following  the  t ransrolt /receive 
bit  shall  indicate  mode  control  when  the  value  is  00000  or  11111  as  indi¬ 
cated  in  MlL-STD-i553. 

1.1.1.1.1.1  Loglca^  Interlace  Ov!.  Wner  the  i  i.ve  tits  toll  owing,  tiic 

"■  ransmit -•  receive  bit:  art-  other  tt;.'!-.  ■(liOu  and  ill..,  the^  shal*  be  used 
a'  Logical  Interfax  Codes  ir.  ar;  f^r..an-t  with,  paras-:  aph  5 . TBl'  wnicn  wil. 
define  the  logica^  oeition  of  the  sra.idarr.  intert  a,.-.' . 

.  l.j.j.I  Int  ormat  i  or:  Trans  :«r!  Ttit  data  but  mav  empj.c}-  triiee- 

nossiblv-'  modes  of  informatioi.  trins-e’  ■  si,  aircraft -t.-'-srore  transfer, 

C2  ■  store-to-alrcraf  t  transfer,  .and  ' ■  ator-'-f  o-st  ore  transfer.  These 
m.jaes  will  operate  a.s  describe.,  ir  1  51 1 ,  paragrani  4. 3. 3. 6. 


..Svb§y§ten5 _ 1  Data  Bus  A 


standard  tnterf 


5. 2. 1.2  Stoi'v;  on  Data  Bus.  The  score  shall  meet  the  requirements  for  a 
remote  terminal  as  defined  in  MIL-STD-1553  and  shall  respond  to  the  air¬ 
craft  stores  management  data  bus  as  a  remote  terminal. 

'5.2. 1.3  Aircraft  on  Data  Bus.  The  aircraft  shall  be  responsible  for 
sending  data  bus  commands,  participating  in  data  transfer,  receiving 
status  response  and  monitoring  system  status  as  defined  for  the  bus 
controller  in  KIL-STD-1553 . 

5.2. 1.4  hiectrical  Interface  Requirements.  The  store  shall  meet  the 
electrical  requirements  of  a  remote  terminal  interface  with  a  transformer 
coupled  stub  as  defined  in  paragraph  4.5.1  of  MIL-STD-1553.  The  aircraft 
shall  meet  the  electrical  interface  requirements  of  a  transf ornier  coupled 
stub  as  defined  in  paragraph  4.5.2  of  MIL-STD-1553. 

5. 2. 1.5  Data  Bus  Requirements.  The  requirements  for  redundant  data  buses 
as  specified  in  paragraph  4.6  of  MIL-STD-1553  shall  apply. 

5.2. 1.6  Electromagnetic  Compatibility.  The  generation  of  and  suscepti¬ 
bility  of  electromagnetic  interference  shall  be  controlled  in  the  store 
and  aircraft.  The  design  shall  meet  MIL-STD-461,  Notice  3  and  shall  be 
tested  in  accordance  with  MIL-STD-462,  Notice  2.  The  specific  suscepti¬ 
bility  requirements  of  MIL-STD-461,  Notice  3  listed  below  shall  be  Included 
as  a  minimum. 

Electric  Field  -  RS03 

Magnetic  Field  -  RS02 

5.2.2  Fiber  Optic  Data  Bus.  The  standard  interface  contains  a  provision 
for  two  fiber  optic  contacts  to  accommodate  technology  advances  that  are 
expected  to  produce  DoD  approved  and  sanctioned  fiber  optic  digital  data 
buses  for  aircraft  and  scores.  Standards  have  not  been  established  for 
transmission  of  serial  digital  multiplex  data  over  fiber  optic  data  buses. 

As  standards  evolve,  they  will  incorporate  in  part,  or  in  total,  into  this 
standard,  and  will  be  accommodated  in  either  the  physical  connector  suggested 
herein,  or  in  a  separate  physical  connector. 

5.2.3  High  Bandwidth  Signals.  The  SSI  connector  shall  contain  four  coaxial 
contacts  for  bidirectional  transfer  of  high  bandwidth  signals  between  the 
aircraft  and  stores,  and  a  fifth  contact  for  transmission  of  store  audio 
data.  The  aircraft  (SMS)  shall  assign,  monitor,  control,  and  route  these 
signals  to  their  proper  destination.  Typical  high  bandwidth  line  application 
Includes:  video,  very  high  speed  digital  and  analog,  and  Radio  Frequency 
(RF)  signals.  When  video,  Time  Correlation  Pulse,  or  RF  signals  are  required, 
they  shall  be  allocated  as  follows: 

5.2.3. 1  Video .  High  Bandwidth  Line  1  (and  continuing  in  order  of  priority 
through  Line  4,  if  needed)  shall  be  used  for  the  bidirectional  transfer  of 
video  type  signals  between  the  aircraft  and  stores.  The  electrical  charac- 


teristlcs  of  the  video  shall  be  In  accordance  with  EIA  Standard  RS-330, 
with  the  following  exceptions: 


1.  Sync  pulse  amplitude  shall  be  .8  ~  .08  volts. 

2.  Video  sensor  load  impedance  shall  be  93  ohms,  1^10%. 

3.  Signal  can  he  bidirectional. 

Video  shall  be  323  lines,  or  375  lines,  in  accordance  with  EIA 
Standard  RS-1A3A. 

5. 2. 3. 2  Time  Correlation  Pulse.  TC?  signal  when  required  shall  be  assigned 
to  High  Bandwidth  Line  3.  The  function  ot  this  circuit  is  to  transfer  ‘1;- 
ferential  digital  target  signals  from  the  store.  'peclfic  character  1st  1 's 
of  Che  TCP  signal  are  TBD. 


5.2. 3.  3  Radio  Frequency.  .RP  signals,  when  required,  shall  be  assigned  te 
High  Bandwidth  Line  4.  Typically,  this  circuit  transfers  Global  Positicring 
System  IGPS)  PJ  data  from  the  aircraft  to  the  store's  navigational  subsystem 

5.2.4  Store  Address  Lines.  The  aircraft  shall  supply  address  line  outputs 

(5  Interface  address  lines,  1  parity  line,  and  1  address  line  return)  to 
each  store  interface.  A  logic  "one"  shall  be  an  open  circuit  lOOK  ohms 

DC)  referenced  to  the  address  line  return.  A  logic  "zero"  shall  be  ^10 
ohms  DC  referenced  to  the  address  line  return.  Address  assignments  sha_l 
be  made  such  that  each  store  station  has  a  separate  and  unique  address. 

Each  assigned  address  plus  parity  shall  contain  an  odd  number  of  "ones  . 

3.2.5  Aircraft  Power.  Application  and  control  of  all  power  to  the  store 
shall  reside  within  the  aircraft  (normally  a  function  of  the  stores  manage¬ 
ment  system).  Aircraft  power  is  specified  for  both  the  SSI  (Figure  3a)  and 
the  .Auxiliary  Power  (Figure  3b)  connectors.  However,  the  Auxiliary  Power 
connector  shall  only  be  used  for  unique  nigh  power  applications  ,i,e.,  .-.uH. 
pods).  Not  all  stores  will  require  or  have  orovisione  for  handling  rhlt 
newer,  nor  will  all  aircraft  stations  ce  able  to  supply  thi?^  hipl'.  power. 

Tne  maximum  total  aircraft  power  recv.1''-i  "v  a  store  in  any  operating  mrce 

net  exceed  the  power  r  equ  1  veme  n,  t  -'.'ecltled  j£  Jw  .  ^n  lOdltrrn,  n  . : 
cr-ni't  power  shall  be  applied  to  the  irreitaoe  for  i.'uual  to  or  gre.iter  .na 
OU  milliseconds  prior  to  its  lo  r  tn  st're.  Jtrailel  air  r..,' 

store  power  requirements  are  sn*  1 ;  :  ici.ows: 


DC  Power.  M II-STD- ’!Vt  .  •/  ,  r  .v  .it',  be  “  illirw'.ng  exceotlcnr 

'-■.I.'.'..'.  /nlta^e.  Vbe  airr.i't  '...i..  i;  ;up;:lying  . o-  ,  ' 

within  :h*'  t  lim:t:el  .  i;  '  ieT'v. (■<, 

.2.1.1. 2  Iver-vnl  tuKu .  "he  .airrr.ir-  na.;  "revide  interlace  cr'tect'lou 
ayain.sl  nve vo  1 1  .ages  in  cxi  es.s  '  '■  'ver-vc  .luges  netwe' 

.8  '/cits  an.al;  te  :e  'J-  't  '  .  n/er-vo  It  ig.-s 


3. 2. 3. 1.3  Cl. Trent .  The  aircralt  shall  be  capable  of  providing  the 
following  current  within  the  voltage  iimitations  defined  in  3.2.3.1.i.. 

i  .  j  .  I  .  i: .  1  Power  i  ,  Power  2  and  Kmergeney  lett  ison  hine.s.  ;  to  lO 
amperes  p  -r  ’line. 

3. 2. 5. 1.3. 2  Power  3  Lines.  0  to  23  amperes  .max)  per  line. 

:  2.  ' . .r.ltial  jtore  Powit.  0  '  .■>  i  ampere  .max' 

.  2  .  . .  .  . :.-.o . i.ir. .  -'ower  i.  Power  1,  P.iwer  iimerveney  Jet:. son, 

-iTvi  iLore  PoV'-r  *..ncs  -iiuii--!.  '>t“  .i.so  i.a  c.  cd  .iL  t  n*.  i^rt  i  <i  .  itiLfri.ii  f 

r.d  ;o  -  a*.,  t.  er.dcii  L  u '■‘v  irit*  air'rafi  .  paL  u  ui’.c  at-r  .  Lai¬ 
s'. a  .  '■..r  ;  Me  tec..i  . .  ,  j  .  'rjii  aiiii  ..  .li.l.  i.iiiMerc  i 

1 1"  y'  u  i  V  T'.  t  r.  T;  •  J  t-  .  .s  l  i  ii  t*  .^w  c  r  i  !  .  I'l  i .  j  ’ .  . 

power  1  ine.s  are  .'.thL:  '..le  ^’owei  >n  ar  Power  -ff  .  .  t  ion . 

3  1  .  1  Return  ..i  nes .  Power  rower  2,  and  i-owei  ill  .lavt  .eo.irari 

and  vseieted  returns  wattiin  the  interlace,  however,  ioili-al  Store  .'hower 
-xeiur;.  and  Power  i  Ri.:tarn  ire  eorsaon.  -M.su.  rimer ger.,- 1  etti.son  .xeturn 
ana  Power  2  Petarn  ^re  ....'nsnon, 

■'.r.o.l.b  Rise  T  im>-  .  T.he  rise  time  lor  all  DC  grower  lines  .shall  .not 
exceed  1  millisecond  from  1  volt  to  23./ 5  volts  -ander  the  onditions  stateo 
in  5.2.,  ,1.1  and  5 . 2 . S . i . 3 . 

5. 2. 5. 2  aC  Power.  MTL-STD-70i  shall  apply  with,  the  following  exceptions. 

5. 2. 5. 2.1  Vol  tage .  The  aircraft  shall  'oe  capable  of  suppiving  .1  ii..'- 

AC,  iTED51,  400  Hertz,  three-phase,  <  wire,  w-ye  connecteii  power  with.n  i.ce 
current  llmltat ions  defined  in  5.2. 5.2.3. 

.5  .  1  .  1 . 2  .  _  Over- vol  tage  .  The  aircraft  shall  provide  init-rla'.e  pr.iect.en 
ipain.-t  ver-vol  tages  in  exce.s.s  ->r  '.'BD  volts.  '  K/er  ,.i>.'.es  h'lwe., 

■j'.l’-i  .and  TBD  'cits  sn.ill  c/'  l;;r..'-e.l  to  ''.'BD  tij  xsec  oau.s  jt  le.ws.  -ve: 
/c:ta/e.s  of  Le.^s  Than  TBD  vcl  t,i  ^’:.ill  .'e  limii.i.'U  ■'  .i  liC'  seconds  . 


.  .le  .i .  re r  ; ;  ;  c.,i 


■  f'  .V  .  dng 


■  i  AC,'..  Aux  ;  1 


.  I'C  .nuepeuc,/  " 


a  ■  ,  :i  e  -  1  ■ 


5.3  Physical  Interface  Definition.  The  aircraft/store  physical  inter¬ 
face  consists  of  the  SSI  and  Auxiliary  Power  connectors,  and  the  inter¬ 
connecting  umbilical  harness.  Detailed  connector  requirements  are  con¬ 
tained  in  Appendix  A.  Specific  physical  interface  characteristics  are 
as  follows: 

5.3.1  Wiring  and  Cabling.  The  selection  and  installation  of  wiring 
and  cabling  as  it  pertains  to  the  scope  of  this  interface  shall  be  in 
accordance  with  MIL-W-5088. 

5.3.2  Wiring  and  Shielding  Termination  and  Grounding.  The  termination 
of  wiring  and  shielding  and  the  fabrication  of  cable  harnesses,  as  it 
affects  the  integrity  of  electrical  signals  through  this  Interface,  shall 
be  in  accordance  with  AFSC  DH  1-4,  Chapter  5,  Section  5B,  Design  Note  5B5, 
unless  otherwise  specified  herein. 

5.3.3  Electromagnetic  Interference.  The  cablingand  shielding  terminating 
at  this  interface,  as  it  affects  the  electrical  integrity  of  the  signals, 
shall  meet  the  requirements  of  MIL-STD-461,  Notice  3,  Test  Method  RS03, 

200  volts  per  meter  test  level  per  paragraph  6.19.2.  Shielding  braid 
attenuation  shall  be  65  DB  or  greater  from  14  KHz  to  10  GHz. 

5.3.4  Static  Discharge  Survival.  Static  discharge  of  500  pf  capacitor 
at  1'20  kilovolts  through  a  5-kohm  resistor  to  an  interface  connector 
shell  shall  not  damage  the  interface. 

5.3.5  Environmental  Factors.  Those  components  and  associated  wiring  of 
the  aircraft/store  configuration  which  affect  the  integrity  of  electrical 
signals  through  the  interface  shall  meet  the  same  level  of  requirements 
for  the  environmental  envelope  as  specified  for  the  electrical  connector 
in  Appendix  A,  as  applicable. 

5.3.6  Store  Receptacle  Connector  Orientation  and  Mounting.  Orientation 
and  mounting  applies  to  both  the  SSI  and  Auxiliary  Power  connectors. 

5.3.6. 1  Top  Mounting.  With  the  connector  positioned  such  that  the 
longitudinal  axis  (the  axis  that  traverses  the  connector  from  front  to  bark 
of  the  connector)  is  in  the  vertical  plane  and  the  connector  face  is  fating 
upward,  the  master  keyway  shall  be  in  the  forward  position  on  the  store 
longitudinal  axis  (See  Figure  5). 

5. 3. 6. 2  Rear  Mounting.  With  the  connector  positioned  such  that  the  longi¬ 
tudinal  axis  is  in  the  horizontal  plane  and  the  connector  face  is  faring 
rearward  (aft),  the  master  keyway  shall  be  in  the  up  po.sition  on  the  store 
vertical  axis  (See  Figure  5). 

5. 3.6. 3  Mounting  Alignment  and  Integrity.  The  store  receptacle  mounting 
shall  be  designed  to  prevent  the  master  keyway  from  becoming  misaligned 
with  the  predetermined  position.  The  retaining  force  of  the  mounting 
shall  be  compatible  with  the  lanyard  release  force. 
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5. 3.6.4  Receptacle  Position.  The  location  of  the  receptacle  connector 
shall  be  in  accordance  vith  MIL-A-8591  and  NATO  Standardization  Agreement, 
STANAG  3558,  for  lug  mounted  stores.  The  location  for  rail-launched  stores 
is  to  be  determined. 

5.3.7  Insert  Arrangement.  The  final  insert  dimensional  geometry  Is  t  ’i 
determined  through  a  detailed  analysis  of  signal  classes  (sensltlv. . 
pulse,  RF)  and  the  relationship  of  interference,  sensltivitv.  dr 
temperature  loading  factors  between  the  respective  (  inult 

and  6b  depict,  in  non-dimensional  geometry,  a  rom'.'.t 

tacts  for  the  electrical  signal  sets  contalne.j  i-  '  ■  ispe. 

tively.  The  connector  shell  size  Is  r  fie>  •  -•  dianeter. 

It  is  estimated  that  this  shell  sir-  -■  ..  ti  25.  The 

number  and  type  of  spare  cont a  t 

5.3.8  Expose  1  Re  •  i  ,  .  •  .-'l  oHed  pins  In  the  store  re- 

ceptailr  ,!!■«  .  r  .  ren  -  e  roupling  after 

l-sipri  shall  incorporale 

f'  i' 'I  ••  -I'ta.  leis)  ircm  EMI  to  the  same  level 


■  '  '  ’  t  r  Definition.  This  section  of  the  standard  defines 
■  .  ir...  Lurt.i  data  transfer  procedure  which  is  consistent  with 

.  -r-'ments  set  forth  in  the  digital  command/response,  time  division 
n  .  •  1,  :  exirifi  standard  (KIL-STD-1553) ,  and  provides  for  standardization 
o;  information  transfer  (logical  interface)  across  the  aircraft/ store 
Interface.  Included  will  be  interface  message  traffic  and  information 
coding  format.  Details  of  this  portion  of  the  standard  are  TBD. 


1.  Refer  to  Table  1  for  pin 
function. 

2.  This  pin  arrangement  is  for 
illustrative  purposes  only. 

Gauge  3*  Spare  pins  are  not  shovm. 

^  0  © 

12  16  20 


Figure  6a .  SSI  Connector  -  insert  arrangement 


TABLE  1 


ELECTRICAL  SIGNAL  SETS 


SSI  CONNECTOR 
AUXILIARY  POWER  CONNECTOR 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector. 


PIN; 

TITLE: 

FUNCTION: 

SOURCE; 

DESTINATION: 

RETURN; 

CONTACT : 

CHARACTERISTICS : 
LOAD: 

REMARKS: 


A 

High  Bandwidth  Line  1 

Provide  signal  path  for  video  or  any  high  bandwidth 

Aircraft/Store 

Aircraf t/Store 

Coaxial  shield 

Size  12  coaxial 

Type  of  signal:  Video  or  any  high  bandwidth 
See  remarks 


This  line  can  be  used  to  carry  video  or  any  high 
bandwidth  signals  between  aircraft  and  store.  The 
exact  function  of  this  line  shall  be  determined  by 
the  type  of  store  being  carried  and  shall  be  con¬ 
trolled  by  the  aircraft  stores  management  system. 
When  used  for  video,  parameters  shall  be  in  accor¬ 
dance  with  EIA  Standard  RS-330  with  the  following 
exceptions: 


1.  a  (sync  pulse  amplitude)  will  be  .8  +  .08  volts. 

2.  The  standard  load  Impedance  of  the  video  sensor 
shall  be  93  ohms  "t  10  percent. 


3.  Video  shall  be  525  lines,  or  875  lines  in  accor¬ 
dance  with  EIA  Standard  RS-343A 


TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN: 

TITLE: 

FUNCTION: 

SOURCE: 

DESTINATION: 

RETURN: 

CONTACT: 

CHARACTERISTICS : 
LOAD: 

REMARKS: 


B 

High  Bandwidth  Line  2 

Provide  signal  path  for  video  or  any  high  bandwidth 
signal  to/from  aircraft/store. 

Aircraft/Store 

Aircraft/Store 

Coaxial  shield 

Size  12  coaxial 

Type  of  signal:  Video  or  any  high  bandwidth 
See  remarks 

This  line  can  be  used  to  carry  video  or  any  high 
bandwidth  signals  between  aircraft  and  store.  The 
exact  function  of  this  line  shall  be  determined  by 
the  type  of  store  being  carried  and  shall  be  con¬ 
trolled  by  the  aircraft  stores  management  system. 
When  used  for  video,  parameters  shall  be  In  accor¬ 
dance  with  EIA  Standard  RS-330  with  the  following 
exceptions: 

1.  a  (sync  pulse  amplitude)  will  be  .8  ^  .08  volts. 

2.  The  standard  load  impedance  of  the  video  sensor 
shall  be  93  ohms  i  10  percent. 

3.  Video  shall  be  525  lines,  or  875  lines  in  accor¬ 
dance  with  EIA  Standard  RS-3A3A. 


23 


411 


TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIK: 

TITLE; 

FUNCTION: 

SOURCE: 

DESTINATION: 

RETURN: 

CONTACT: 

CHARACTERISTICS: 

LOAD; 

REMARKS: 


C 

High  Bandwidth  Line  3 

Provide  signal  path  for  video  or  any  high  bandwidth 

Aircraf t/Store 

Aircraft/Store 

Coaxial  shield 

Size  12  coaxial 

Type  of  signal:  Video  or  any  high  bandwidth 
See  remarks 

This  line  can  be  used  to  carry  video  or  any  high 
bandwidth  signals  between  aircraft  and  store.  The 
exact  function  of  this  line  shall  be  determined  by 
the  type  of  store  being  carried  and  shall  be  con¬ 
trolled  by  the  aircraft  stores  management  system. 
When  used  for  video,  parameters  shall  be  in  accor¬ 
dance  with  EIA  Standard  RS-330  with  the  following 
exceptions; 

1.  a  (sync  pulse  amplitude)  will  be  .8  -  *08  volts. 

2.  The  standard  load  Impedance  of  the  video  sensor 
shall  be  93  ohms  1  10  percent. 

3.  Video  shall  be  525  lines,  or  875  lines  in  accor¬ 
dance  with  EIA  Standard  RS-343A. 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN:  D 

TITLE:  High  Bandwidth  Line  4 

FUNCTION:  Provide  signal  path  for  video  or  any  high  bandwidth 

signal  to/from  aircraf t/store. 

SOURCE:  Aircraf t/Store 

DESTINATION:  Aircraft/Store 

RETURN:  Coaxial  shield 

CONTACT:  Size  12  coaxial 

CHARACTERISTICS:  Type  of  signal:  Video  or  any  high  bandwidth 

LOAD:  See  remarks 

REMARKS:  This  line  can  be  used  to  carry  video  or  any  high 

bandwidth  signals  between  aircraft  and  store.  The 
exact  function  of  this  line  shall  be  determined  by 
the  type  of  store  being  carried  and  shall  be  con¬ 
trolled  by  the  aircraft  stores  management  system. 
When  used  for  video,  parameters  shall  be  in  accor¬ 
dance  with  EIA  Standard  RS-330  with  the  following 
exceptions: 

1.  a  (sync  pulse  amplitude)  will  be  .8  1  .08  volts. 

2.  The  standard  load  impedance  of  the  video  sensor 
shall  be  93  ohms  t.  10  percent. 

3.  Video  shall  be  525  lines,  or  875  lines  in  accor¬ 
dance  with  EIA  Standard  RS-343A, 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


1 


i 


PIN; 

E 

TITLE: 

Store  Audio 

FUNCTION: 

Target  presence  and  lock-on  indicator 

to  pilot 

SOURCE; 

Store 

DESTINATION: 

Aircraft 

RETURN: 

Power  1  Return,  pin  H 

CONTACT; 

Size  20 

CHARACTERISTICS : 

400  to  2000  Hertz  amplitude  modulated 
Zero  to  30  volts  RMS 

carrier . 

LOAD: 

lOK  -  20R  ohms 

REMARKS: 

Store  audio  output  to  indicate  target  presence 
and/or  lock-on. 

f 

■f 


TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN: 

TITLE: 

FUNCTION: 

SOURCE : 

DESTINATION: 

RETURN: 

CONTACT: 

CHARACTERISTICS: 

LOAD: 

REMARKS: 


F 

Dat  Bus  A(+) 

Transmits  serial  digital  multiplex  command, 
control,  and  status  data  between  the  aircraft 
and  the  store 

Aircraf  t 

Bus  interface  electronics  in  store 
Data  Bus  A(-) ,  pin  G 
Size  20 

Bidirectional  signal,  Manchester  biphase  lAW  MIL-STD- 
1553 

To  be  determined 

See  5.2.1.  Part  of  a  2-wire  twisted  shielded  cable. 
Shield  carried  through  connector.  Reference  pins 
G  and  H. 


Table  l.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN; 

TITLE: 

FUNCTION : 

SOURCE: 

DESTINATION; 

RETURN: 

CONTACT : 

CHARACTERISTICS: 

LOAD: 

REMARKS: 


G 

Data  Bus  A(-) 

Transmits  serial  digital  multiplex  command, 
control,  and  status  data  between  the  aircraft 
and  the  store 

Aircraft 

Bus  interface  electronics  in  store 
Data  Bus  A(+) ,  pin  F 
Size  20 

Bidirectional  signal,  Manchester  biphase  lAW  MIL-STD- 
:553 

To  be  determined 

See  5.2.1.  part  of  a  2-wlre  twisted  shielded  cable. 
Shield  carried  through  connector.  Reference  pins 
F  and  H 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN: 

TITLE: 

FUNCTION: 

SOURCE: 

DESTINATION: 

RETURN: 

CONTACT: 

CHARACTERISTICS: 

LOAD: 

REMARKS: 


H 

Bus  A  Shield 

Protects  Data  Bus  A  from  spurious  signals 

Aircraft 

Store 

Not  applicable 
Size  20 

Multiplex  data  shield  0  VDC 
Not  applicable 

Part  of  a  2-wire  twisted  shielded  cable.  Reference 
pins  F  and  G 
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TABLE  1. 


Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN: 

TITLE: 

FUNCTION: 

SOURCE: 

DESTINATION; 

RETURN: 

CONTACT: 

CHARACTERISTICS : 

LOAD: 

REMARKS: 


Data  BusC-f) 

Transmits  serial  digital  multiplex  command, 
control,  and  status  data  between  the  aircraft 
and  the  store 

Aircraft 

Bus  Interface  electronics  in  store 
Data  Bus  B(-),  pin  K 
Size  20 

Bidirectional  signal,  Manchester  biphase  LAW  MIL-STD- 
1553 

To  be  determined 

See  5.2.1.  Part  of  a  2-wlre  twisted  shielded  cable. 
Shield  carried  through  connector.  Reference  pins 
K  and  L 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN: 

TITLE: 

FUNCTION: 

SOURCE: 

DESTINATION: 

RETURN: 

CONTACT: 

CHARACTERISTICS: 

LOAD: 

REMARKS: 


K 

Data  Bus  B(-) 

Transmits  serial  digital  multiplex  command, 
control,  and  status  data  between  the  aircraft 
and  the  store 

Aircraft 

Bus  Interface  electronics  In  store 
Data  Bus  B  (-(■),  pin  J 
Size  20 

Bidirectional  signal,  Manchester  biphase  lAW  MIL-STD- 
1553 

To  be  determined 

See  5.2.1.  Part  of  a  2-wlre  twisted  shielded  cable. 
Shield  carried  through  connector.  Reference  pins 
J  and  L 
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TABLE  1. 


Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN; 

TITLE: 

FUNCTION: 

SOURCE: 

DESTINATION: 

RETURN; 

CONTACT: 

CHARACTERISTICS : 
LOAD: 

REMARKS: 


L 

Bus  B  Shield 

Protects  Data  Bus  B  from  spurious  signals 

Aircraft 

Store 

Not  applicable 
Size  20 

Multiple  data  shield  0  VDC 
Not  applicable 

Part  of  a  2-wire  twisted  shielded  cable.  Reference 
pins  J  and  K 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIK: 


M 


TITLE: 

FUNCTION: 


SOURCE: 


Fiber  Optic  Data  Bus  A 

Transmits  serial  digital  multiplex  command, 
control,  and  status  data  between  the  aircraft 
and  the  store 

Aircraft 


DESTINATION:  Store 


RETURN:  Not  applicable 

CONTACT:  Size  12  contact  for  fiber  optic  cable 


CHARACTERISTICS:  To  be  determined 


LOAD:  Not  applicable 

REMARKS:  Growth  provision  for  standard  Interface 

This  pin  will  not  be  used  until  fiber  optic 
communications  techniques  are  further  developed. 

Fiber  optic  communication  may  take  place  through 
a  separate  advanced  Interface  connector. 
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TABLE  1. 

PIN: 

TITLE; 

FUNCTION: 

SOURCE: 

DESTINATION: 

RETURN: 

CONTACT: 

CHARACTERISTICS 

LOAD: 

REMARKS: 


Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


N 

Fiber  Optic  Data  Bus  B 

Transmits  serial  digital  multiplex  command, 
control,  and  status  data  between  the  aircraft 
and  the  store 

Alrcraf  t 

Store 

Not  applicable 

Size  12  contact  for  fiber  optic  cable 
To  be  determined 
Not  applicable 

Growth  provision  for  standard  Interface 

This  pin  will  not  be  used  until  fiber  optic 
communications  techniques  are  further  developed. 

Fiber  optic  communication  may  take  place  through 
a  separate  advanced  Interface  connector. 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN; 

TITLE: 

FUNCTION: 

SOURCE: 

DESTINATION: 

RETURN: 

CONTACT: 

CHARACTERISTICS: 

LOAD; 

REMASKS 


P 

Address  Line  1  (most  significant  bit  -  MSB) 

Transmits  store  digital  data  bus  identification 
address  bit  from  aircraft  to  bus  interface 
electronic  system 

Aircraft  stores  management  system 

Bus  Interface  electronics  In  store 

Address,  Return  Pin  W 

Size  20 

Logic  1  ■  Open  Circuit  (^100  K  ohms) 

Logic  0  ■  Short  Circuit  connected  to  Pin  W 
(<  10  ohms) 

Not  applicable 

Reference  pins  R,  S,  T,  U,  V,  and  W 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN: 

TITLE: 

FUNCTION: 

SOURCE; 

DESTINATION: 

RETURN: 

CONTACT: 

CHARACTERISTICS : 

LOAD: 

RQIARKS: 


R 

Address  Line  2  (MSB-1) 

Transmits  store  digital  data  bus  Identification 
address  bit  from  aircraft  to  bus  Interface 
electronic  system 

Aircraft  stores  management  system 

Bus  Interface  electronics  In  store 

Address,  Return  Pin  W 

Size  20 

Logic  1  ■  Open  Circuit  ( >  100  K  ohms) 

Logic  0  “  Short-Circuit  connected  to  Pin  W 
(  ^  10  ohms) 

Not  applicable 

Reference  pins  P,  S,  T,  U,  V,  and  W 


TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN: 

TITLE: 

FUNCTION: 

SOURCE : 

DESTINATION: 

RETURN: 

CONTACT: 

CHARACTERISTICS : 

LOAD: 

REMARKS: 


S 

Address  Line  3  (MSB-2) 

Transmits  store  digital  data  bus  identification 
address  bit  from  aircraft  to  bus  interface 
electronic  system 

Aircraft  stores  management  system 

Bus  interface  electronics  in  store 

Address,  Return  Pin  W 

Size  20 

Logic  1  =  Open  Circuit  (>100  K  ohms) 

Logic  0  =  Short  Circuit  connected  to  Pin  W 
(  <  10  ohms 

Not  applicable 

Reference  pins  P,  R,  T,  U,  V,  and  W 
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-  Continued 


1 Anuc  ^ 

PIN: 

TITLE; 

FUNCTION : 

SOURCE: 

DESTINATION: 

RETURN; 

CONTACT; 

CHARACTERISTICS; 

LOAD: 

REMARKS; 


T 

Address  Line  4  (MSB-4) 

Transmits  store  digital  data  bus  identification 
address  bit  from  aircraft  to  bus  interface 
electronic  system 

Aircraft  stores  management  system 

Store/bua  interface  electronics 

Address,  Return  Pin  W 

Size  20 

Logic  1  »  Open  Circuit  (  >  100  K  ohms) 

Logic  0  *=  Short  Circuit  connected  to  Pin  V) 
(^10  ohms) 

Not  applicable 

Reference  pins  P,  R.  S,  U,  V,  and  W 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN: 

TITLE: 

FUNCTION: 

SOURCE: 

DESTINATION: 

RETURN: 

CONTACT: 

CHARACTERISTICS : 

LOAD: 

REMARKS: 


U 

Address  Line  5  (least  significant  bit  -  LSB) 

Transmits  store  digital  data  bus  Identification 
address  bit  from  aircraft  to  bus  Interface 
electronic  system 

Aircraft  stores  management  system 

Bus  Interface  electronics  In  store 

Address,  Return  Pin  W 

Size  20 

Logic  1  =  Open  Circuit  100  K  ohms) 

Logic  0  =  Short  Circuit  connected  to  Pin  W 
(^10  ohms) 

Not  applicable 

Reference  pins  P,  R.  S,  T,  V,  and  U 


PIN:  V 

TITLE:  Parity  Line 

FUNCTION:  Provides  store  digital  data  bus  Identification 

address  parity  bit  from  aircraft  to  bus  Interface 
electronics  system 

SOURCE:  Aircraft  stores  management  system 

DESTINATION:  Bus  interface  electronics  in  store 

RETURN:  Address,  Return  Pin  W 

CONTACT:  Size  20 

CHARACTERISTICS:  Logic  1  =  Open  Circuit  ( >  100  K  ohms 

Logic  0  “  Short  Circuit  (<  10  ohms  connected  to 
Pin  Y) 

REMARKS:  Reference  pins  P,  R,  S,  T,  U,  and  W.  This  line  will 

be  set  to  a  logical  1  when  the  sum  of  the  bits  on  the 
5  address  lines  is  even.  This  line  will  be  set  to  a 
logical  0  when  the  sum  of  the  bits  on  the  otner  5 
address  lines  Is  odd  (ODD  PARITY) . 


UO 

428 


TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN; 

TITLE: 

FUNCTION: 

SOURCE; 

DESTINATION: 

RETURN: 

CONTACT: 

CHARACTERISTICS: 

LOAD: 

REMARKS: 


W 

Address  Line  Return 

Provide  a  return  path  between  aircraft  and  bus 
interface  electronics  for  the  address  lines. 

Store 

Bus  interface  electronics  in  store 
Not  applicable 
Size  20 


Not  applicable 

Reference  pins  P,  R,  S,  T,  U,  and  V.  This  line  is 
the  address  return  for  the  address  lines.  It  shall 
be  Isolated  from  ground  and  not  connected  to  store 
structure. 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN: 

TITLE: 

FUNCTION: 

SOURCE: 

DESTINATION: 

RETURN: 

CONTACT: 

CHARACTERISTICS: 

LOAD: 

REMARKS: 


X 

Emergency  Jettison 

Operates  from  aircraft  emergency  jettison  bus. 
Provides  mechanically  and  electrically  isolated 
jettison  signal  to  store  interface 

Aircraft  emergency  jettison  controller 

Store  jettison  activator  system 

Power  2  Rtn,  pin  j 

Size  16 

Discrete  signal 

28  VDC:  Jettison  store  order 

Open:  Jettison  not  ordered 

Maximum  current  is  10  amperes 

High-priority  aircraft  command.  Requires 
dedicated  hardwire  circuit 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PINS:  Y,  2 

TITLE:  Store  Present  Interlock 


FUNCTION: 

SOURCE: 

DESTINATION: 


Indicates  store-present/store- gone  status  to 
aircraft 

Aircraft  (store-present  indication),  pin  Y 
Store 


RETURN:  Aircraft,  pin  Z 

CONTACT:  Size  20 


CHARACTERISTICS: 


Pin  Y  to  pin  2  shortened  indicates  store  present  ( S  10  ohms) 
Pin  Y  to  pin  2  open  Indicates  store  gone  ( >  100  K  ohms) 


LOAD:  Not  applicable 

REMARKS:  Positive  store  disconnect/release  indicator  to 

aircraft.  See  figure  3a. 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN: 

TITLE; 

FUNCTION: 

SOURCE: 

DESTINATION; 

RETURN: 

CONTACT : 

CHARACTERISTICS : 

LOAD: 

REMARKS: 


a 

115  VAC  400  HZ  PHASE  A 

Provides  one  phase  of  the  115  volt,  400  Hertz, 

AC  power  to  the  store 

Aircraft 

Store 

115  VAC  400  HZ  RTN,  pin  d 
Size  16 

Power  Signal:  115  VAC,  400  Hertz,  Phase  A, 

4-wlre,  wye-connected  power 

Maximum  sustained  current  is  10  amperes 

Aircraft  power  shall  be  in  accordance  with  MIL-STD- 
704,  The  aircraft  shall  provide  interface  fault 
protection.  Reference  pins  b,  c,  and  d 


44 


TABLE  1.  Electrical  Signal  Set  -  SSI  Connector .  -  Continued 


PIN: 

TITLE: 

FUNCTION: 

SOURCE : 

DESTINATION: 

RETURN: 

CONTACT: 

CHARACTERISTICS: 

LOAD: 

REMARKS: 


b 

115  VAC  400  HZ  PHASE  B 

Provides  one  phase  of  the  115  volt,  400  hertz 
ac  power  to  the  store 

Aircraft 

Store 

115  VAC  400  HZ  RTN,  pin  d 
Size  16 

Power  Signal:  115  VAC,  400  Hertz,  Phase  B, 

4-wire,  wye-connected  power 

Maximum  sustained  current  Is  10  amperes 

This  power  shall  be  in  accordance  with  MIL-STD-704. 
The  aircraft  shall  provide  Interface  fault  protec¬ 
tion.  Reference  pins  a,  c,  and  d 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector .  -  Continued 


PIN: 

c 

TITLE: 

115  VAC  400  HZ  PHASE  C 

FUNCTION: 

Provides  one  phase  of  the  115  volt,  400  hertz, 
power  to  the  store 

SOURCE: 

Aircraft 

DESTINATION: 

Store 

RETURN: 

115  VAC  400  HZ  RTN,  pin  d 

CONTACT: 

Size  16 

CHARACTERISTICS: 

Power  Signal:  115  VAC,  400  Hertz,  Phase  C 

4-wire,  wye~connected  power 

LOAD: 

Maximum  sustained  current  is  10  amperes 

REMARKS: 

This  power  shall  be  in  accordance  with  MIL-STD-704 
The  aircraft  shall  provide  Interface  fault  protec¬ 
tion.  Reference  pins  a,  b,  and  d 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN: 

TITLE: 

FUNCTION: 

SOURCE : 

DESTINATION: 

RETURN: 

CONTACT; 

CHARACTERISTICS : 
LOAD: 

REMARKS: 


d 

115  VAC  400  HZ  RTN 

Provides  a  neutral  and  a  return  path  for  unbalanced 
loads  connected  to  the  115  VAC,  400  hertz,  three- 
phase  four-wire,  wye-connected  power  supplied  by 
the  aircraft 

Store 

Aircraft 

This  is  the  ac  power  return  signal 
Size  16 

Power  Signal:  Neutral-O  VAC 
Not  applicable 

Phases  A,  B,  and  C  are  nominally  120  degrees  out 
of  phase  with  each  other;  therefor?-,  the  current 
in  the  neutral  wire  (return)  is  no  equal  to  ihe 
simple  sum  of  the  maximum  phas''  currents.  Reference 
pins  a,  b,  and  c 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN: 

TITLE: 

FUNCTION; 

SOURCE: 

DESTINATION: 

RETURN: 

CONTACT : 

CHARACTERISTICS: 

LOAD: 

REMARKS: 


e 

Initial  Store  Power 

Activates  bus  Interface  electronic  system  In 
store  to  enable  store  operation  on  aircraft 
digital  data  buses 

Aircraft  28  VDC  power  bus 

Bus  Interface  electronic  system  In  store 

POWER  1  RTN,  pin  h 

Size  20 

+28  VDC  (nominal)  applied  when  store  electrical 
bus  Interface  activation  Is  required 

1.00  ampere  maximum 

Power  shall  be  supplied  per  MIL-STD-704 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


f 

S't  VOC  i 


aircraft  power  to 


S'/ekCi:.'  Aircraft 

DESTINATION:  Score 

RETURN:  POWER  1  RT.N.  pin  h 

CONTACT:  Size  16 

CHARACTERISTICS:  28  TOC  power 

LOAD:  Maximun:  sustained  current  is  10  anperes 

REMARKS:  The  28  TOC  power  shall  be  in  accordance  with  KIL-STD- 

704  except  that  the  aircraft  shall  be  capable  of 
supplying  22  TOC  minimum  to  the  interface  at  the 
above  specified  current  level.  The  aircraft  shall 
provide  interface  fault  protection 


TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN; 

TITLE; 

FUNCTION; 

SOURCE: 

DESTINATION; 

RETURN; 

CONTACT: 

CHARACTERISTICS: 

LOAD; 

REMARKS: 


g 

28  VDC  POWER  2 

Supplies  continuous  28  VDC  aircraft  power  to  the 
store 

Alrcraf  t 

Store 

POWER  2  RTN,  pin  j 
Size  16 
28  VDC  power 

Maximum  sustained  current  Is  10  amperes 

The  28  VDC  power  shall  be  In  accordance  with  MIL- 
STD-704  except  that  the  aircraft  shall  be  capable 
of  supplying  22  VDC  minimum  to  the  Interface  at 
the  above  specified  current  level.  The  aircraft 
shall  provide  interface  fault  protection 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN; 

h 

TITLE: 

POWER  1  RTN 

FUNCTION: 

Provides  a  return  path  between  the  aircraft  and 
store  f-or  28  VDC  Power  1 

SOURCE: 

Aircraft  and  store 

DESTINATION: 

Store  and  aircraft 

RETURN: 

No  applicable 

CONTACT: 

Size  16 

CHARACTERISTICS : 

0  VDC  power 

LOAD: 

Maximum  sustained  current  In  the  ground  return  line 
Is  11  amperes 

REMARKS: 

Shall  be  Isolated  from  ground  and  not  Connected 
to  weapon  structure.  Reference  pins  E  and  e 
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TABLE  1.  Electrical  Signal  Set  -  SSI  Connector.  -  Continued 


PIN; 

j 

TITLE: 

POWER  2  RTN 

FUNCTION: 

Provides  a  return  path  between  the  aircraft  and 
store  for  28  VDC  Power  2 

SOURCE : 

Aircraft  and  store 

DESTINATION: 

Store  and  aircraft 

RETURN; 

Not  applicable 

CONTACT: 

Size  16 

CHARACTERISTICS: 

0  VDC  power 

LOAD: 

Maximum  sustained  current  in  the  ground  return 
line  is  10  amperes 

REMARKS: 

Shall  be  Isolated  from  ground  and  not  connected 
to  structure  in  weapon.  Reference  pins  x  and  g 

5.’ 

ii. 


TABLE  1, 

PIN: 

TITLE: 

FUNCTION: 

SOURCE: 

DESTINATION: 

RETURN: 

CONTACT : 

CHARACTERISTICS 

LOAD: 

REMARKS: 


Electrical  Signal  Set  -  SSI  Connector.  -  Concluded 


k 

Structure  Ground 

Provides  ground  safety  interconnect  between 
aircraft  and  store  structure  ground 

Aircraft  frame  ground 

Store  frame  ground 

Not  applicable 

Size  16 


0  VDC 

Not  applicable 

Shall  not  be  used  for  signal  or  power  return 
path 
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I 


TABLE  1. 

PIN: 

TITLE: 

FUNCTION: 

SOURCE: 
DESTINATION : 
RETURN: 

CONTACT: 

CHARACTERISTICS 

LOAD: 

REMARKS: 


Electrical  Signal  Set  -  Auxiliary  Power  Connector. 


1 

115  VAC  400  Hz  PHASE  A 

Provides  one  phase  of  the  115  volt,  400  Hertz, 

AC  power  to  the  store 

Aircraft 

Store 

115  volt  400  Hz  RTN,  pin  7  and  8 
Size  12 

Power  Signal:  115  VAC,  400  Hz,  Phase  A 
4  -  wire,  wye-connected  power 

Maximum  sustained  current  Is  23  amperes. 

Aircraft  power  shall  be  In  accordance  with 
MlL-STD-704,  The  aircraft  shall  provide  Inter¬ 
face  fault  protection.  This  pin  supplies  half 

of  the  available  power  of  phase  A.  Reference  ^ 

pins  1  through  8.  | 


TABLE  1.  Electrical 


PIN: 

TITLE: 

FUNCTION': 

SOURCE: 

DESTINATION: 

RETURN: 

CONTACT: 

CHARACTERISTICS : 

LOAD: 

REMARKS: 


Signal  Set  -  Auxiliary  Power  Connector.  -  Continued 


2 

115  VAC  400  Hz  PHASE  A 

Provides  one  phase  of  the  115  volt,  400  Hertz, 
AC  power  to  the  store 

Aircraft 

Store 

115  volt  400  Hz  RTN,  pin  7  and  8 
Size  12 

Power  Signal:  115  VAC,  400  Hz,  Phase  A, 

4  -  wire,  wye-connected  power 

Maximum  sustained  current  Is  23  amperes. 

Aircraft  power  shall  be  in  accordance  with 
MIL-STD-704.  The  aircraft  shall  provide  Inter¬ 
face  fault  protection.  This  pin  supplies  half 
of  the  available  power  of  phase  A.  Reference 
pins  1  through  8. 
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TABLE  1.  Electrical  Signal  Set  -  Auxiliary  Power  Connector.  -  Continued 


PIN; 

TITLE: 

FUNCTION : 

SOURCE: 
DESTINATION : 
RETURN: 

CONTACT: 

CHARACTERISTICS: 

LOAD: 

RIMARKS: 


3 

115  VAC  400  Hz  PHASE  B 

Provides  one  phase  of  the  115  volt,  400  Hertz, 
AC  power  to  the  store 

Aircraft 

Store 

115  volt  400  Hz  RTN,  pin  7  and  8 
Size  12 

Power  Signal:  115  VAC,  400  Hz,  Phase  A, 

4  -  wire,  wye-connected  power 

Maxlnum  sustained  current  Is  23  amperes. 

Aircraft  power  shall  be  in  accordance  with 
MIL-STD~704.  The  aircraft  shall  provide  Inter¬ 
face  fault  protection.  This  pin  supplies  half 
of  the  available  power  of  phase  B.  Reference 
pins  1  through  8. 


5b 


PIN: 


4 


TITLE:  115  VAC  400  Hz  PHASE  B 

FUNCTION:  Provides  one  phase  of  the  115  volt,  400  Hertz, 

AC  power  to  the  store 

SOURCE:  Aircraft 

DESTINATION:  Store 

RETURN:  115  volt  400  Hz  RTN,  pin  7  and  8 

CONTACT:  Size  12 

CHARACTERISTICS:  Power  Signal;  115  VAC,  400  Hz,  Phase  A, 

4  -  wire,  wye-connected  power 

LOAD;  Maximum  sustained  current  Is  23  amperes. 

REMARKS:  Aircraft  power  shall  be  In  accordance  with 

MIL-STD-704,  The  aircraft  shall  provide  Inter¬ 
face  fault  protection.  This  pin  supplies  half 
of  the  available  power  of  phase  B.  Reference 
pins  1  through  8. 


PIN; 


5 


TITLE; 

FUNCTION ; 

SOURCE; 
DESTINATION ; 
RETURN; 

CONTACT; 

CHARACTERISTICS ; 

LOAD; 

REMARKS; 


115  VAC  400  Hz  PHASE  C 

Provides  one  phase  of  the  115  volt,  400  Hertz, 
AC  power  to  the  store 

Aircraft 

Store 

115  volt  400  Hz  RTN,  pin  7  and  8 
Size  12 

Power  Signal;  115  VAC,  400  Hz,  Phase  A, 

4  -  wire,  wye-connected  power 

Maximum  sustained  current  is  23  amperes. 

Aircraft  power  shall  be  in  accordance  with 
MlL-STD-704.  The  aircraft  shall  provide  Inter¬ 
face  fault  protection.  This  pin  supplies  half 
of  the  available  power  of  phase  C.  Reference 
pins  1  through  8. 
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TABLE  1.  Electrical  Signal  Set  -  Auxiliary  Power  Connector.  -  Continued 


PIN:  6 

TITLE;  115  VAC  400  Hz  PHASE  C 

FUNCTION:  Provides  one  phase  of  the  115  volt,  400  Hertz, 

AC  power  to  the  store 

SOURCE:  Aircraft 

DESTINATION :  Store 

RETURN:  115  volt  400  Hz  RTN,  pin  7  and  8 

CONTACT:  Size  12 

CHARACTERISTICS:  Power  Signal:  115  VAC,  400  Hz,  Phase  A 

4  -  wire,  wye-connected  power 

LOAD:  Maximum  sustained  current  Is  23  amperes. 

REMARKS:  Aircraft  power  shall  be  In  accordance  with 

MIL-STD-704.  The  aircraft  shall  provide  inter¬ 
face  fault  protection.  This  pin  supplies  half 
of  the  available  power  of  Phase  C.  Reference 
pins  1  through  8. 
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TABLE  1 .  Electrical 


PIN: 

TITLE: 

FUNCTION: 

SOURCE: 
DESTINATION : 
RETURN: 

CONTACT: 

CHARACTERISTICS : 
LOAD: 

REMARKS: 


Signal  Set  -  Auxiliary  Power  Connector.  -  Continued 


7 

115  VAC  400  Hz  RTN 

Provides  a  neutral  and  a  return  path  for 
unbalanced  loads  connected  to  the  115  VAC, 

400  Hertz,  three-phase  four  wire,  V7ye-con- 
nected  power  supplied  by  the  aircraft 

Aircraft 

Store 

This  Is  the  AC  power  return  signal 
Size  12 

Power  Signal:  Neutral  -  0  VAC 
Not  applicable 

Phases  A,  B  and  C  are  nominally  120  degrees 
out  of  phase  with  each  other;  therefore,  the 
current  in  the  neutral  wire  (return)  Is  not 
equal  to  the  simple  sun  of  the  maximum  phase 
currents.  This  pin  Is  half  of  the  return  line. 
Reference  pins  1  through  8. 
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TABLE  1.  Electrical  SlRnal  Set  -  Auxiliary  Power  Connector  -  Continued 


PIN: 

TITLE: 

FUNCTION : 

SOURCE : 
DESTINATION : 
RETURN: 

CONTACT : 

CHARACTERISTICS : 
LOAD: 

REMARKS: 


8 

115  VAC  400  Hz  RTN 

Provides  a  neutral  and  a  return  path  for 
unbalanced  loads  connected  to  the  115  VAC, 

400  Hertz,  three-phase  four  wire,  wye-con¬ 
nected  power  supplied  by  the  aircraft 

Aircraft 

Store 

This  Is  the  AC  power  return  signal 
Size  12 

Power  Signal:  Neutral  -  0  VAC 
Not  applicable 

Phases  A,  B  and  C  are  nominally  120  degrees  out 
of  phase  with  each  other;  therefore,  the  current 
In  the  neutral  wire  (return)  Is  not  equal  to  the 
simple  sum  of  the  maximum  phase  currents.  This 
pin  Is  half  of  the  return  line.  Reference  pins 
1  through  8. 
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TABLE  1 .  Electrical 

PIN: 

TITLE; 

FUNCTION: 

SOURCE: 

DESTINATION ; 

RETURN: 

CONTACT: 

CHARACTERISTICS : 
LOAD: 

REMARKS: 


Signal  Set  -  Auxiliary  Power  Connector.  -  Continued 


9 

28  VDC  POWER  BUS  C 

Supplies  continuous  28  VDC  aircraft  power  to 
the  store. 

Aircraft 

Store 

Power  return,  pins  11  and  12 
Size  12 
28  VDC  power 

Maximum  sustained  current  Is  23  amperes 

The  28  VDC  power  shall  be  In  accordance  with 
MIL-STD-704  except  that  the  aircraft  shall  be 
capable  of  supplying  22  VDC  minimum  to  the  Inter¬ 
face  at  the  above  specified  level.  The  aircraft 
shall  provide  interface  fault  protection.  This 
pin  Is  half  of  the  DC  lines.  Reference  pins  9 
through  12. 
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TABLE  1.  Electrical  Signal  Set  -  Auxiliary  Power  Connector.  -  Continued 


PIN: 

TITLE: 

FUNCTION: 

SOURCE: 

DESTINATION: 

RETURN: 

CONTACT: 

CHARACTERISTICS ; 
LOAD: 

REMARKS: 


10 

28  VDC  POWER  BUS  C 

Supplies  continuous  28  VDC  aircraft  power  to 
the  store 

Aircraft 

Store 

Power  return,  pins  11  and  12 
Size  12 
28  VDC  power 

Maximum  sustained  current  Is  23  aiq>ere8 

The  28  VDC  power  shall  be  in  accordance  with 
MIL-STD-704  except  that  the  aircraft  shall  be 
capable  of  supplying  22  VDC  minimum  to  the  Inter¬ 
face  at  the  above  specified  level.  The  aircraft 
shall  provide  Interface  fault  protection.  This 
pin  is  half  of  the  DC  lines.  Reference  pins  9 
through  12. 
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TABLE  1.  Electrical 


PIN; 

TITLE; 

FUNCTION ; 

SOURCE; 
DESTINATION : 
RETURN: 

CONTACT; 

CHARACTERISTICS 

LOAD: 

REMARKS: 


Signal  Set  -  Auxiliary  Power  Connector.  -  Continued 


11 

POWER  RETURN  C 

Provides  a  return  path  between  the  aircraft 
and  store  for  28  VDC  Power  Bus  C 

Store 

Aircraft 

This  Is  a  DC  power  return  line 
Sl2e  12 
0  VDC  power 

Maximum  sustained  current  in  the  ground  return 
line  is  23  amperes. 

Shalx  be  isolated  from  ground  and  not  connected 
to  structure  In  weapon.  This  pin  Is  one  half 
of  the  DC  return  lines.  Reference  pins  9  through 
12. 
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TABLE  1 .  Electrical  Signal  Set  -  Auxiliary  Power  Connector.  -  Continued 


12 

POSTER  RETURN  C 

r  1 

Provides  a  return  paiii  between  tne  aircraft 
and  store  for  2E  VjC  Power  Bus  C 

SOUaCL : 

Store 

DESTIi'iATION : 

Aircraft 

RETURN: 

This  is  a  DC  power  return  line 

CONTACT : 

Size  12 

CHARACTERISTICS: 

0  VDC  power 

LOAD: 

Maximum  sustained  current  in  the  ground  return 
line  is  23  amperes. 

REMARKS: 

Shall  be  isolated  from  ground  and  not  connected 
to  structure  in  weapon.  This  pin  is  one  half  of 
the  DC  return  lines.  Reference  pins  9  through 

12. 
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APPENDIX  A 


6.  ELECTRICAL  CONNECTOR  REQUIREMENTS 

6.1  Introduction.  This  section  prescribes  detail  electrical  connector 
physical  requirements  for  the  standard  aircraft/store  Interface.  Specific 
physical  and  operating  requirements  for  the  standard  Interface  connector 
are  given.  The  following  requirements  shall  be  In  accordance  with  MIL- 
C-38999,  or  subsequent  revisions.  The  following  material  has  been  repro¬ 
duced  from  MIL-C- 38999  co  minimize  the  need  for  additional  documents  to 
obtain  the  requirements .  This  material  applies  to  Series  IV  connectors 
only.  Requirements  not  specific  to  MIL-C- 38999  are  also  presented  (where 
possible)  which  Indicate  a  reasonable  alternative  to  a  design  In  preference 
to  nothing  at  all  or  a  "to  be  determined".  The  underlined  paragraph  number, 
e.g.  4.8.2,  Is  the  appropriate  test  paragraph  of  MIL-C-38999  and  the  paren¬ 
thetical  number  (3.5.6)  is  the  requirement  paragraph  of  MIL-C-38999. 

6.2  Definitions . 

6.2.1  Electrical  Connector  Terminology.  See  Section  3  of  MIL-STD-1353 
for  standard  electrical  connector  terminology  definitions. 

6.2.2  Requirements .  Requirements  described  in  the  following  sections  are 
of  two  types.  The  first.  Section  6.3  (General)  are  written  in  general  terms 
to  address  major  connector  characteristics  definitely  required  for  the 
standard  Interface  applications.  Characteristic  descriptions  have  been 
derived  from  known  technology  capabilities  and/or  an  analysis  of  necessary 
connector  features.  The  second  type,  contained  in  6.4  (Detailed),  and 
referenced  to  MIL-C-38999,  are  considered  to  be  a  boiler  plate  requirements 
applicable  to  and  contained  in  all  airborne  connector  specifications.  The 
standard  Is  not  Intended  to  form  a  basis  for  the  formulation  of  revisions 
to  existing  specifications. 

6.3  General  Requirements. 

6.3.1  Design  and  Construction.  (3.4)  Connectors  and  accessories  shall  be 
designed  and  constructed  to  withstand  normal  handling  Incident  to  installa¬ 
tion  and  maintenance  In  service.  Connector  receptacle  Interchangeability 
control  dimensions  and  accessory  Interface  dimensions  shall  be  as  specified 
on  Figure  1.  All  accessories  (plugs)  designed  to  be  used  with  HIL-C- 38999 
connectors  must  conform  to  Figure  2. 

6.3.2  Types . 

a.  Receptacle,  aircraft  shall  contain  socket  contacts. 

b.  Plug,  aircraft  umbilical  to  store  shall  contain  socket  contacts. 

6.3.3  Flnlst^.  The  finish  shall  be  electroless  nlckle  coating  (conductive) 
-65°  C  to  +200°  C,  followed  by  cadmium  plate  0.0001  inch  (0.003mm)  minimum 
in  accordance  with  QQ-P-416,,  Type  II. 
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6.3.4  Interchangeability  and  Intermateabillty.  The  connectors  (Figures  1. 

2  and  3)  shall  be  completely  Interchangeable  and  Intermateable  from  all 
vendor  sources  and  production  runs.  (3.5)  All  connectors  having  the  same 
part  number  shall  be  completely  Interchangeable  with  each  other  with  re¬ 
spect  to  Installation  and  performance. 

6.3.5  Pin  Protection.  The  receptacle  connector  shall  be  designed  to 
prevent  the  plug  shell  from  contacting  the  receptacle  pins  under  any 
conditions  of  mating.  This  design  Is  commonly  referred  to  as  "scoop  proof". 

6.3.6  Coupling .  Connectors  shall  be  coupled  to  counterpart  connectors  by 
means  of  a  breech  mechanism  (Series  IV) .  The  mechanism  shall  Include  a 
means  of  maintaining  the  mated  connector  in  full  engagement.  The  coupling 
ring  shall  be  knurled  or  fluted  to  facilitate  coupling  and  shall  be  cap¬ 
tivated.  The  coupling  nuts  of  all  connectors  shall  have  a  blue  color  band 
in  accordance  with  EIA  RS-359,  indicating  a  rear  release  contact  retention 
system. 

6. 3. 6.1  Ease  of  Coupling.  (3.4. 6.1)  Counterpart  connectors  of  any  arrange¬ 
ment  shall  be  capable  of  being  fully  coupled  and  uncoupled  In  a  normal  and 
accessible  location  without  the  use  of  tools. 

6.3.7  Engagement  and  Locking.  Counterpart  connectors  shall  be  capable  of 
full  engagement  and  disengagement  without  the  use  of  tools.  Engagement  of 
connectors  shall  be  defined  as  mated  Insert  faces.  For  Series  IV,  complete 
coupling  shall  be  accomplished  by  approximately  90°  clockwise  rotation  of 
the  coupling  nut,  and  shall  Incorporate  a  positive  detent  action  at  both 
the  mated  and  unmated  position,  providing  an  audible  and  tactile  indication 
of  complete  coupling,  as  well  as  an  anti-decoupling  force.  A  red  band  shall 
be  located  on  the  plug  so  as  to  be  visible  when  unmated  and  fully  covered 
when  completely  mated. 

6.3.8  Polarization  of  Connector  Shells.  (3.4.6. 3)  Polarization  of  connector 
shells  shall  be  accomplished  by  means  of  five  integral  keys  and  suitable 
matching  keyways  on  the  counterpart  (See  Figures  1  and  2).  Polarization 
shall  be  accomplished  before  initial  engagement  of  the  coupling  ring.  During 
axial  engagement,  pins  shall  not  touch  sockets  or  the  insert  face  until 
polarization  has  been  achieved. 

6. 3. 8.1  Pin  to  Pin  Mating  Prevention  (Series  IV  only).  Series  connectors 
shall  be  provided  with  kev  keyway  widths  arranged  so  as  to  prevent  a 
plug  with  pin  contacts  fro.  tng  mated  with  a  receptacle  with  pin  contacts. 

6.3.9  Electrical  Cc.  . _ pulty.  The  connectors  shall  be  designed  to  provide 

positive  electrical  continuity  between  mated  shells  prior  to  contact  engage¬ 
ment  . 


6.3.10  Electromagnetic  Interface  (EMI)  Grounding  Spring  Fingers.  EMI 
grounding  spring  fingers  shall  be  provided  and  shall  be  designed  in  a 
manner  which  will  ensure  proper  engagement  of  the  mating  shells  and  provide 
electrical  contact. 


6.3.11  Lanyard.  The  lanyard  shall  be  mounted  to  the  plug  connector  (alr- 
craf t-to-8tore  6. 3. 2. 6)  such  that  rotation  of  the  connector  for  engagement 
will  not  shorten  the  effective  length  of  the  lanyard.  The  design  of  the 
lanyard  to  connector  attaching  feature  shall  provide  for  attaching  and 
removing  lanyard  cables  using  the  normal  compliment  of  standard  shop  tools. 
Design  of  the  lanyard  to  connector  attaching  feature  shall  ensure  total 
integrity  of  the  connector  to  meet  the  required  lanyard  retention  force. 

6.3.11.1  Lanyard  Retention.  The  lanyard,  including  all  hardware  and  joints, 
shall  withstand  an  axial  tensile  force  of  150  pounds  minimum. 

6.3.11.2  Lanyard  Release  Force.  The  lanyard  release  force  shall  be  no  less 
than  20  pounds  and  no  more  than  AO  pounds.  Direction  of  lanyard  pull  shall 
be  at  any  angle  within  30  degrees  of  the  connector  longitudinal  autls . 

6.3.12  Shielding  Braid  Termination.  The  plug  connector  backshell  shall 
provide  for  shielalng  braid  termination  to  allow  integral  bounding  of 
cable  envelop  shielding  to  the  connector. 

6.3.13  Water  Sealing.  The  plug  connector  backshell  shall  be  designed  to 
ensure  complete  sealing  from  entrance  of  water.  A  suitable  quality  assurance 
test  shall  be  specified  to  encompass  the  alrcraf t/store  operational  environ¬ 
ment  . 


6.3. lA  Electrical  Contacts.  The  following  contact  types  shall  be  provided 
as  specified,  in  MIL-C-39029A,  or  from  vendor  sources  as  applicable.  The 
range  of  size  within  the  types  specified  shall  be  compatible  with  the 
cavity  size  In  the  Insert  specified  for  this  standard.  Contact  types  of 
one  size  shall  be  completely  interchangeable  and  intermateable  within  the 
cavity . 

a.  Power  Contacts  -  shielded  and  unshielded,  crimp  removable. 

b.  Coaxial  Contacts 

c.  Fiber  Optics 

6.3.1A.1  Contact  Sizes.  See  Table  1,  MIL-STD-1760 . 

6. 3.1 A. 2  Insert  Arrangement.  TBD 

6.3.1A.3  Connector  Shell  Size.  A  size  25  connector  shell  shall  be  used 
for  the  insert  of  6. 3.1 A. 2. 


6.3.15  Electromagnetic  Interference  Effectiveness.  Unless  otherwise  stated 
herein,  MIL-STD-A61  of  current  issue,  will  apply.  When  tested  as  specified 
In  paragraph  A. 7. 2?  of  MIL-C-38999  of  current  issue,  the  EMI  shielding 
effectiveness  of  mated  shells  shall  not  be  less  than  that  specified  in 
Table  I. 
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TABLE  II.  EMI  Shielding  Ef f ectlveneaa  (Class  W) 

Frequency  Leakage  Attenuation 

MHz  db  minimum 


.014-100 

90 

100 

90 

200 

85 

300 

83 

400 

81 

800 

76 

1,000 

75 

1,500 

69 

2,000 

65 

3,000 

61 

4,000 

58 

6,000 

55 

10,000 

50 

6.3.15.1  Electromagnetic  Pulse  (EMP)  Susceptibility.  To  be  determined. 

6.3.16  Receptacle  Mounting.  The  most  common  mounting  designs  are  flange 
and  jam  nut. 

6.3.16.1  Store  Mounting.  The  type  of  receptacle  mounting  design  is  optional. 
The  type  of  mounting  used  shall  have  a  structural  strength  competlble  with 
the  lanyard  release  force.  The  type  mounting  shall  be  sufficiently  rigid 

to  prevent  the  receptacle  turning  from  a  predetermined  fixed  master  polari¬ 
zation  key  position. 

6.3.16.2  Aircraft  Mounting.  The  type  of  receptacle  mounting  design  shall 
be  a  flange.  The  type  mounting  shall  be  sufficiently  rigid  to  prevent  the 
receptacle  turning  from  a  predetermined  fixed  master  polarization  key 
position. 

6.4  Detailed  Requirements. 

6.4.1  Materials.  (3.3) 

6.4. 1.1  Metals .  Metals  shall  be  of  a  corrosion-resistant  type  or  shall  be 
plated  or  treated  to  resist  corrosion. 

6. 4. 1.2  Dissimilar  Metals  and  Compatible  Couples.  When  dissimilar  metals 
are  used  in  Intimate  contact  with  each  other,  protection  against  electrolysis 
and  corrosion  shall  be  provided.  The  use  of  dissimilar  metals  In  contact, 
which  tend  toward  active  electrolytic  corrosion,  (particularly  brass,  copper, 
or  steel  used  In  contact  with  aluminum  or  aluminum  alloy)  Is  not  acceptable. 
However  metal  plating  or  metal  spraying  of  dissimilar-base  metals  to  provide 
similar  or  suitable  abutting  surface  Is  permitted.  The  use  of  dissimilar 
metals  separated  by  a  suitable  Insulating  material  is  also  permitted.  Dissim¬ 
ilar  metals  and  compatible  couples  are  defined  In  requirement  16  of  MIL-STD-454. 
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6.4. 1.3  Hydrolytic  Stability.  (3. 3. 1.2)  All  nonmetalllc  material  shall 
be  selected  to  meet  the  hydrolytic  revision  resistance  requirements  specified 
In  requirement  47  of  MIL-STD-454. 

6.4.2  Components .  (3.3.2)  Material  for  specific  components  of  the  connector 
shall  be  as  follows: 

6. 4. 2.1  Class  F.  (3. 3. 2.1) 

a.  Shell  -  Impact  extruded  or  machined  aluminum  alloy. 

b.  Coupling  ring,  jam  nut,  and  potting  ring  -  machined  aluminum  alloy. 

c.  Insert  (molded)  -  reinforced  epoxy  resin  or  other  suitable  rigid 
dielectric  material. 

d.  Spring  fingers  -  heat  treated  beryllium  copper  or  corrosion- 
resistant  steel. 

e.  Filler  compound  -  RTV  silicone  conforming  to  MTL-A-46146. 

f.  Gaskets,  grommet,  and  Interface  seals  -  silicone  or  fluorocarbon 
elastomer. 

6. 4. 2. 2  Fungus  Resistant.  (3.3.3)  Material  used  in  the  construction  of 
these  connectors  shall  be  fungus  Inert  in  accordance  with  requirement  4 
of  MIL-STD-454. 


6. 4. 2. 3  Nonmagnetic  Materials.  (3.3.4)  The  relative  permeability  of  the 
connector  assembly  shall  be  less  than  2.0  when  measured  with  an  indicator 
conforming  to  MIL-I-17214. 


6.4.3 


Insert  Design . 


(3.4.2) 


6.4. 3.1  Environment  Resisting  Classes.  (3.4.2. 1)  The  entire  insert  and 
wire  sealing  or  wire  supporting  member  of  the  environment  resisting  assemblies 
shall  be  essentially  one  Integral  part,  designed  to  provide  suitable  sealing 
and  support  around  the  wires  and  be  nonremoval.  The  rigid  dielectric  shall 
be  one  integral  piece.  The  design  shall  be  such  as  to  permit  the  removal 
and  replacement  of  individual  contacts  into  their  connector  inserts  with  an 
MS27534  or  MS27495  installing/removal  tool.  The  contact  locking  device 
shall  be  contained  in  the  rigid  dielectric  insert  and  shall  so  retain  the 
contacts  as  to  meet  the  contact  retention  requirements  of  this  specification, 
see  Figure  4.  Inserts  shall  be  secured  to  prevent  rotation.  All  pin  con¬ 
tact  inserts  shall  have  a  resilient  interface  seal  bonded  to  the  front  face 
in  accordance  with  the  applicable  standards.  Socket  insert  entry  holes  and 
pin  "donut"  rings  shall  conform  to  MIL-C- 38999  Figure  5.  Sealing  to  coaxial 
cable  terminated  to  shielded  contacts  may  be  accomplished  by  means  of  separate 
resilient  bushings.  If  separate  resilient  bushings  are  required,  they  shall 
be  furnished  with  the  connector. 


6.4.4  Mating  Seal.  (3. 4. 3. 3)  Plugs  and  receptacles  with  pin  inserts  shall 
have  a  resilient  face  with  individual  pin  barriers.  The  pin  barrier  pro¬ 
jections  shall  seal  in  their  respective  lead-in  chambers  of  the  hard  face 
socket  insert.  The  resilient  interfaclal  seal  shall  provide  individual 
contact  seals  in  the  mated  condition  to  ensure  circuit  isolations  between 
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each  contact  and  contact  to  shell.  The  plugs  (Series  IV)  shall  Incorporate 
an  0-ring  peripheral  seal. 


6, A. 5  Shell  (3. A. A)  Shells,  Including  mounting  flanges,  shall  be  one-piece 
construction  and  shall  be  designed  to  retain  their  Inserts  in  one  position, 
both  axially  and  with  respect  to  rotation,  by  mechanical  means.  Molding 
shall  be  used  as  the  retention  means  for  environment  resisting  connectors. 

The  receptacle  shells  of  crimp  contact  connectors  shall  have  a  blue  color 
band  in  accordance  with  ElA  RS-359,  indicating  a  rear  release  contact  re¬ 
tention  system.  The  color  band  shall  be  located  so  that  it  is  readily  vis¬ 
ible  to  any  person  servicing  a  mounted  receptacle  connector. 

6. A. 5.1  Spring  Fingers .  (3.4.A.1)  Spring  fingers  shall  be  designed  to 
make  electrical  contact  with  the  mating  shell  without  interfering  with 
proper  engagement.  The  spring  shall  be  retained  about  the  shell  periphery. 
Minimum  engagement  of  spring  fingers  shall  be  O.OAO  (1.02Ti!m)  prior  to  contact 
engagement  (Series  IV). 

6. A. 5. 2  Jam-Nut  Mounting  Receptacles.  (3. A. A. 2)  Jam-nut  mounting  receptacles 
shall  be  provided  with  a  mounting  nut  DoD-C-38999/28  Series  IV,  all  with  pro¬ 
visions  for  locking,  and  an  ”0"  ring  MS9021. 

6. A. 6  Lubrication.  (3.A.6.A)  The  breech  mechanism  on  Series  IV  connectors 
may  be  coated  with  a  suitable  dry  film  lubricant  to  MIL-L-A6010  (non-graphite). 

6. A. 7  Plating.  (3. A. 8) 

6. A. 7.1  Contacts  (Crimp).  (3. A. 8.1)  The  plating  and  the  plating  thickness 
on  crimp  contacts  shall  be  as  specified  in  MIL-C-39029. 

6. A. 7. 2  Shell  and  Accessory  Hardware.  (3. A. 8. 2)  Unless  otherwise  specified, 
the  finish  on  the  shells  and  accessory  hardware  shall  be  in  accordance  wl*  . 
the  following  designation: 

Series  IV,  Class: 

F  -  Electrically  conductive  electroless  nickle  conforming  to 
MIL-C-2607A,  Class  3  or  A,  followed  by  cadmium  plate  0.0001 
inch  (O.OOlmm)  minimum  in  accordance  with  QQ-P-A16,  Type  II. 

Use  of  suitable  underplate  is  permissible. 
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TA3LE  III.  Contact  cnp.igcrr.ent  and  separation  forces. 


Initial 

After  conditioning 

Mating 

end 

size 

Minimum 

separation 

force 

(ounces) 

Maximum 

average 

engagement 

force 

(ounces) 

Maximum 

engagement 

force 

(ounces) 

Minimum 

separation 

force 

(ounces) 

Maximum 

average 

engagement 

force 

(ounces) 

Maximum 

engagement 

force 

(ounces) 

Minimum 
diameter 
Ms3197  pin 

Maximum 
diameter 
MS5197  pin 

Maximum 
diameter 
MS3197  pin 

Minimum 
d i ameter 
MS3197  pin 

Maximum 
diameter 
M35197  pin 

' 

Maximum 
diameter 
MS3197  pin 

12 

3 

24 

30 

2.S 

i  29 

36 

16 

2 

24 

30 

l.S 

1  29 

36 

20 

0.7 

12 

18 

0.6 

14 

22 

6.4.8  Contact  engn^ccrr.-jnt  and  separation  force.  The  contact  engagement  and 
separation  force  shall  be  within  the  applicable  limits  specified  in  Table  III, 


6.4.9  Thermal  shock  fall  classes  except  hcrmctics).  (3.8)  IVhen  tested  as 
specified  in  4.7.4,  th.ere  shall  be  no  damage  detrimental  to  the  operation  of 
the  connector. 

6.4.10  Coupling  torgtic.  (.3.10)  hhen  tested  as  specified  in  4.7.6,  the 
coupling  torque  for  ma.ting  and  unmating  of  counterpart  connectors  shall  meet 
the  requirements  of  Table  IV. 


TABLE  IV.  Coupling  torque,  y 


Shell 

size 

Maximum  emgagement 
and  disengagement 

Minimum 

disengagement 

Pound 

Newt  on 

Newton 

inch 

meters 

meters 

2S 

40 

4.6 

s  • 

0.6 

y  For  Series  IV  connectors  with  spring  fingcr.s,  an  axial  force  as  specified 
in  Tabic  III  must  be  encountered  prior  to  coupling  torque  during  engagement, 
and  following  coupling  torque  upon  disengagement. 


6.4.11  Durability .  (.3.11)  Wien  tested  as  specified  in  4.7.7,  the  connectors 

shall  show  no  defects  detrimental  to  the  operation  of  the  connectors  and  shall 
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■neet  the  subsequent  test  requirements  (see  4.4.3). 


6.4.12  Altitude  immersion  (qualification  only)  (except  hermetics) .  (3.. 2) 
When  tested  as  specif,u>cl  in  4.7.8,  the  mated  connector  shall  meet  a  min¬ 
imum  insulation  resistance  of  1,000  and  the  requirements  of  dielectric  with¬ 
standing  voltage  as  specified  in  (3.14)  SO. 17.13. 

6.4.13  Insulation  resistance.  (3. 13) 

6.4.13.1  Insulation  resistance  at  ambient  temperature.  (3.13.1)  When 
tested  as  specified  in  4 . ~ . 9 , 1 ,  the  insulation  resistance  between  any 
pair  of  contacts  and  between  any  contact  and  the  shell  shall  be  greater  than 
5,000  megohms.  Insulation  resistance  after  altitude  immers-ion  shall  be  1,000 
megohms  minimum.  Insulation  resistance  after  humidity  shall  be  100  megohms 
minimum. 


6.4.13.2  Insulation  resistance  at  elevated  temperature.  (3,13,2)  Wlien 
tested  as  specified  in  4 . 7 . 9 . 2  .  the  insulation  resistance  between  any  pair 
of  contacts  and  between  any  contact  and  the  shell  shall  be  greater  than  1  000 
megohms  for  environment  resisting  class  conectors.  ’ 

^£.lectric_withstanding  voltage.  (3,14)  hben  tested  as  specified 
in  4.7. 1_0. 1 ,  or  4.  / .  10. 2,  connectors  shall  show  no  evidence  of  flashover  or 
breakdown . 


6.4.15  Insert  retentuy. 

'Uied) 


(3.15)  hbrn  tested  as  specified  in  4.7.11,  un- 
shnll  retain  their  inserts  in  their  proper  location 


mated  connectors  (m 

in  the  shell  and  there  shall  be  no  evidence  of  cracking,  breaking' separation 
or  loosening  of  parts. 


from  the  she!’ 


6.4.16  Salt  spray  ^corrosion).  (3.16)  hben  tested  as  specified  in  4  7.12 
immated  connectors  slnli  show  no  exposure  of  base  metal  due  to  corrosion  ' 
which  will  adversely  -iffect  performace. 


6*4.17  Electrical  ciic->gemcnt .  (3.18) 

wired,  mated  connectors  sh.iTT  provide  a 
and  (o.050  inch  (1.2"i:im)  .Scries  IV. 


hhen  tested  as  specified  in  4.7.14, 
minimum  of  electrical  engagement  for 


6.4,18  Extcrn.a  1  hcn,liTT*  m-' ;u'nt . 
connoctors  slri  Tl  •  Ii'm  ih.  <  vulnu  o 
opcr.'itions  nor  I  I  iho,*  p,-  .mv 


(3.19)  \\1icn  tested  as  specified  in  4 
of  d.mi.ijM'  ih't  ri iTK'ii 1 ,1 1  to  thoir  normal 
i  n  t  or  iipi  i  on  ol  cloclric.al  c<in  t  i  nu  i  t  y  . 


IS, 


6.4.19  Cont.ict  rctonu^.  (5,2.3)  When  tested  as 
axial  displaoemcnt  o(  the  contact  shall  not  exceed 
damage  to  contacts  or  insert-,  shall  result. 


specified  in  4.7. IP, the 
0.013  inch  (0. 30mm) .  No 


6.4..0  Aj_t_ituec^„  Klu-,,  tested  as  specified  in  4.7.20,  the 

connectors  shall  nc.t  the  requirements  of  the  dielectric  withstanding  volt¬ 
age  at  sea  level  sp  -  'fied  in  (3.14)  .and  insul.ation  resistance  at  amhient 
temperature  specified  ip  (''.ij.i). 


6.4.21  Vibration  (qualification  only).  (3.26)  IVhen  tested  as  specified 
in  4. 7. 22, there  shall  be  no  electrical  discontinuity  and  there  shall  be  no 
disengagenent  of  the  mated  connectors,  backing  off  of  the  coupling  mechanism, 
evidence  of  cracking,  breaking,  or  loosening  of  parts. 

6.4.22  Shock.  (5.27)  Mien  tested  as  specified  in  4.7.23,  there  shall  be 
no  electrical  discontinuity  and  there  shall  be  no  disengagement  of  mated 
connectors,  evidence  of  cracking,  breaking,  or  loosening  of  parts. 

6.4.23  Shell-to-shell  conductivity.  (3.28)  When  tested  as  specified  in 


4.7.24,  the  probes  shall  not  puncture  or  otherwise  damage  the  connector 
finish  and  the  maximum  measured  potential  drop  across  assemblies  shall  be 
as  follows; 

a.  Series  IV  with  spring  fingers: 

1.  Class  W  -  2.5  millivolt 

6.4.24  Humidity .  (3.29)  Mien  tested  as  specified  in  4.7.25,  wired  mated 
connectors  shall  show  no  deteriation  which  will  adversely  effect  performance 
of  connector.  Following  the  test,  insulation  resistance  shall  be  100  megohms 
or  greater. 

6.4.25  Shell  spring  finger  forces.  (3.30)  When  tested  as  specified  in 
4.7.26,  the  forces  necessary  to  engage  and  separate  EMI  plugs  with  reep- 
tacle  shells  shall  be  withiti  the  values  specified  in  Table  V. 

TABLE  V  Shell  spring  finger  forces. 


Minimum 


Pounds  Newton 


.5  2.2 


6.4.26  Ozone  exposure.  (3.32)  IVhen  tested  as  specified  in  4.7.28,  the 
connector  shall  show  no  evidence  of  a  cracking  of  dielectric  material  or 
other  damage  due  to  ozone  exposure  that  will  adversely  effect  performance. 

6.4.27  Fluid  immersion.  (3.53)  When  tested  as  specified  in  4.7.29,  connectors 
shall  meet  the  requirements  for  coupling  torque  (3.10)  and  dielectric 
withstanding  voltage  (3.14). 

6.4.28  Retention  system  fluid  immersion.  (3.33.1)  IVhen  tested  as  specified 


1 

1 


in  4.7,29.1,  the  insert  assemblies  shall  meet  requirements  of  contact  reten¬ 
tion  (3.23).  Effects  of  the  fluids  on  resilient  sealing  shall "not  be  a 
consideration  of  this  test. 


6.4,29  Pin  contact  stability.  (3.34)  IsT^en  tested  as  specified  in  4.7.30, 
the  total  displacement  of  a  reference  point  on  the  contact  tip  end  shall 
not  exceed  the  amount  shown  in  Table  VI. 


TABLE  VI 


Pin  contact  stability. 


Contact  size 

Total  displacement 

Force 

Inch 

MM 

Pounds 

Newton 

20 

HM 

1.37 

0.55 

1 

2.4 

16 

1.91 

1.10 

4.9 

12 

■b 

1.91 

1.10 

4.9 

6.4.30  Contact  walkout.  (3.35)  When  tested  as  specified  in  4.7.31,  contacts 
shall  not  become  dislodged  from  their  normal  position. 


6.4.31  Power  contacts. 


6.4.31.1  Temperature  life. (3.37) 

6.4.31.1.1  Temperature  life  with  contact  loading.  (3.37.1)  When  tested 
as  specified  in  4.7.33. I .  the  contacts  shall  maintain  their  specified 
locations  as  shown  on  figure  1  and  there  shall  be  no  electrical  dis¬ 
continuity. 


6.4.31.1.2  Temperature  life.  (3.37.2)  When  tested  as  specified  in  4.7.33.2, 
for  1,000  hours,  connectors  shall  perform  satisfactory  and  pass  succeding 
tests  in  the  qualification  test  sequence. 

6.4.32  Electrolytic  erosion  (Series  IV).  (3.38)  When  tested  as  specified 
in  4.7.34,  pin  contact  shall  show  no  exposure  of  base  metal  due  to  electro¬ 
lytic  erosion.  Corrosion  deposits  shall  not  be  considered  as  defects. 

6.4.33  Firewal 1 .  (3.39)  Mated  connectors  shall  prevent  passing  of  a 

flame  through  the  connector  for  at  leasr  20  minutes  when  tested  in 
accordance  witli  4.7.35.  Puring  this  period  there  shall  be  no  flame  from 
outgassing  or  other  c.auses  on  the  end  of  tlie  connector  ’■'votected  by  the 
fireqall.  The  current  sincificd  in  4.7.55,  shall  be  api'lied  for  the  first 
five  minutes  without  break  in  electrical  continuity.  During  the  next 
minute  the  connector  shall  draw  no  more  than  2  ampheres  when  a  test  potential 
of  100  to  125  Vac  at  60  llz  is  applied  between  adjacent  contacts  and  be¬ 
tween  contacts  and  the  shell.  (Class  K) 

6.4.34  Coaxial  and  Fiber  Optics  Contacts.  TBD 
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6.4.35  Mark ing.  (3.43)  Connectors  and  accessories  shall  be  metal  or  ink 
stamped  with  the  manufacture's  name  or  trademark,  date.  code,  and  the 

"*5  applicable.  Stamping  shall  be  in  accordance  with 
MIL-STD-128S  where  space  permits.  Metal  stamping  shall  be  accomplished  be¬ 
fore  placing.  The  following  examples  are  illustrative: 
a.  Identification. 


D38999/40 

W 

25 

n 

P 

N 

Specification 

Class 

Shell 

Insert 

Contact 

Polarization 

sheet  No. 

size 

arrangement 

style 

(Figures. 1,  2,  &3) 
(A  letter  is 
required  for 
all  positions) 

b.  Lot 

number 

-  000010. 

6.4.35.1  Contact  location  identification.  (3.43.1)  Contact  locations  shall 
be  identified  as  indicated  on  Figure  TBD  and  the  applicable  military  standard. 
All  positions  shall  be  Identified  on  the  front  and  rear  faces  of  Che  Insert, 
except  where  space  limitations  make  this  impracticable.  Location  of  contact 
identifying  characters  shall  be  in  close  proximity  to  the  holes  but  need  not 
be  placed  exactly  where  indicated  on  the  standard. 

6.4.36  Workmanship.  (3.44)  The  connector  shall  be  fabricated  in  a  manner 
such  that  the  criteria  for  apperance,  fit  and  adherence  to  specified  tol¬ 
erances  are  observed.  Particular  attention  shall  be  given  to  neatness  and 
thoroughness  of  marking  parts,  plating,  welding,  soldering,  riveting,  stack¬ 
ing,  and  bonding.  The  connectors  shall  be  free  from  crazing,  cracks,  voids, 
pimples,  chips,  blisters,  pinholes,  sharp  cutting  edges,  burrs,  and  other 
defects  that  will  effect  life,  serviceability  or  appearance. 
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Because  of  space  constraints  in  this  Proceedings,  the  Ada 
Programming  Language  Reference  Manual  dated  July  1980  has 
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a  copy,  send  your  requests  to: 
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